Me ajude por favor!

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!!! :wink:

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