Olá,
Estou começando a estudar JSP.
Nuam da dando certo essa pagina JSP.
Será q é necessário usar algum servlet, ou so essa JSP funcione?
Outra coisa, criei uma pasta dentro de webapps, e dentro dela criei uma chamada WEB-INF. Também modifiquei o server.xml, e criei o driver ODBC.
Mas mesmo assim tá dando um monte de erros.
Veja a página:
<%@page import="java.sql.*"%>
<html>
<head>
<title>ola jsp</title>
</head>
<%
Connection conn = null;
ResultSet rs = null;
Statement stmt = null;
try
{
Class c = Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
conn = DriverManager.getConnection("jdbc:odbc:testes");
stmt = conn.createStatement();
rs = stmt.executeQuery("select * from clientes");
}
catch(SQLException e)
{
System.out.println("Ocorreu o erro:" + e);
}
%>
<body>
<%=rs.getString(2)%>
</body>
</html>
E qual é o monte de erros?
type Exception report
message
description The server encountered an internal error () that prevented it from fulfilling this request.
exception
org.apache.jasper.JasperException
org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:370)
org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:291)
org.apache.jasper.servlet.JspServlet.service(JspServlet.java:241)
javax.servlet.http.HttpServlet.service(HttpServlet.java:802)
root cause
java.lang.NullPointerException
org.apache.jsp.ola_jsp._jspService(org.apache.jsp.ola_jsp:76)
org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:97)
javax.servlet.http.HttpServlet.service(HttpServlet.java:802)
org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:322)
org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:291)
org.apache.jasper.servlet.JspServlet.service(JspServlet.java:241)
javax.servlet.http.HttpServlet.service(HttpServlet.java:802)
note The full stack trace of the root cause is available in the Apache Tomcat/5.5.9 logs.
vc deve pegar (ou atirar) a exceção ClassNotFoundException para compilar a jsp
pode haver outros erros alem deste
vai q eh tua!!! 
agora q vi o NullPointeException, reparei no rs.getString()
acontece q quando tu cria um ResultSet ele nao aponta pra nenhuma linha, daih tu precisa fazer rs.nex() pra ele ir pra primeira linha dos resultados e ir avançando
vc pode usar
while(rs.next()) {
rs.getString(2);
}
pra mostrar todos os valores da coluna nº2 da tabela resultado
posta pra gente o código do servlet gerado desse teu jsp, nessa linha:
org.apache.jsp.ola_jsp._jspService(org.apache.jsp.ola_jsp:76)
e de onde o objeto dessa linha q esta lançando a NullPointerException estiver sendo inicializado…
Aí ta o servlet gerado por esta JSP.
Valeu.
package org.apache.jsp;
import javax.servlet.*;
import javax.servlet.http.*;
import javax.servlet.jsp.*;
import java.sql.*;
public final class ola_jsp extends org.apache.jasper.runtime.HttpJspBase
implements org.apache.jasper.runtime.JspSourceDependent {
private static java.util.Vector _jspx_dependants;
public java.util.List getDependants() {
return _jspx_dependants;
}
public void _jspService(HttpServletRequest request, HttpServletResponse response)
throws java.io.IOException, ServletException {
JspFactory _jspxFactory = null;
PageContext pageContext = null;
HttpSession session = null;
ServletContext application = null;
ServletConfig config = null;
JspWriter out = null;
Object page = this;
JspWriter _jspx_out = null;
PageContext _jspx_page_context = null;
try {
_jspxFactory = JspFactory.getDefaultFactory();
response.setContentType("text/html");
pageContext = _jspxFactory.getPageContext(this, request, response,
null, true, 8192, true);
_jspx_page_context = pageContext;
application = pageContext.getServletContext();
config = pageContext.getServletConfig();
session = pageContext.getSession();
out = pageContext.getOut();
_jspx_out = out;
out.write("\r\n");
out.write("\r\n");
out.write("<html>\r\n");
out.write("\r\n");
out.write("<head>\r\n");
out.write("<meta http-equiv=\"Content-Language\" content=\"pt-br\">\r\n");
out.write("<meta http-equiv=\"Content-Type\" content=\"text/html; charset=windows-1252\">\r\n");
out.write("<meta name=\"GENERATOR\" content=\"Microsoft FrontPage 4.0\">\r\n");
out.write("<meta name=\"ProgId\" content=\"FrontPage.Editor.Document\">\r\n");
out.write("<title>ola jsp</title>\r\n");
out.write("</head>\r\n");
Connection conn = null;
ResultSet rs = null;
Statement stmt = null;
try
{
Class c = Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
conn = DriverManager.getConnection("jdbc:odbc:testes");
stmt = conn.createStatement();
rs = stmt.executeQuery("select * from clientes");
}
catch(SQLException e)
{
System.out.println("Ocorreu o erro:" + e);
}
out.write("\r\n");
out.write("\r\n");
out.write("<body>\r\n");
out.write("\r\n");
out.write("ola jsp\r\n");
while(rs.next())
{
rs.getString(2);
}
out.write("\r\n");
out.write("</body>\r\n");
out.write("\r\n");
out.write("</html>\r\n");
} catch (Throwable t) {
if (!(t instanceof SkipPageException)){
out = _jspx_out;
if (out != null && out.getBufferSize() != 0)
out.clearBuffer();
if (_jspx_page_context != null) _jspx_page_context.handlePageException(t);
}
} finally {
if (_jspxFactory != null) _jspxFactory.releasePageContext(_jspx_page_context);
}
}
}
se importa em dizer qual é a linha 76…? :roll:
Se eu naum estiver muito errado, o erro esta entre estas linhas:
[code]
while(rs.next())
{
rs.getString(2);
}
out.write("\r\n");
out.write("</body>\r\n");
out.write("\r\n");
out.write("</html>\r\n");
} [/code]
Contando as linhas q estaum em branco.
Valeu