【问题标题】:retrieve data from database table and display it in atable with html从数据库表中检索数据并将其显示在带有 html 的表中
【发布时间】:2014-06-02 05:06:34
【问题描述】:

我是初学者,目前正在完成我的期末学校项目,该项目需要从数据库表中检索数据并在 html 页面中显示数据。我搜索了很多,但仍然没有进展。我通过谷歌链接到这个网站,我看到了一个格式,我尝试做同样的事情,但是在运行代码后我得到了这个错误

异常报告

message An exception occurred processing JSP page /crimeinfo.jsp at line 32 description The server encountered an internal error that prevented it from fulfilling this request.

例外

org.apache.jasper.JasperException: An exception occurred processing JSP page /crimeinfo.jsp at line 32
29:     
30:     
31:     <%List <String> data =(List)request.getAttribute("data");
32:     Iterator <String> itr = data.iterator() ;
33:     for (itr = data.iterator();
34:     itr.hasNext();)
35:     {%>

我需要帮助。我不知道还能做什么。谢谢...

查看crime.xml

<?xml version="1.0" encoding="UTF-8"?>
<!--web.xml code-->
<servlet>
<servlet-name>viewcrimereport</servlet-name>
<servlet-class>viewcrimereport</servlet-class>
<servlet-mapping>
<servlet-name>viewcrimereport</servlet-name>
<url-pattern>viewcrimereport</url-pattern>
</servlet-mapping></servlet>

查看crimereport.java

public class viewcrimereport extends javax.servlet.http.HttpServlet implements javax.servlet.Servlet {
     private ServletConfig config;
     String page = "crimeinfo.jsp";
     public void init(ServletConfig config)
         throws ServletException{
         this.config = config; }
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
    PrintWriter out=response.getWriter();
    response.setContentType("text/html");
    Connection conn = null;
    String url = "jdbc:mysql://localhost/citycrime";
    String userName = "root";
    String passw = "jids";
    PreparedStatement pst = null;
    ResultSet rs;
    ArrayList<String> datalist = new ArrayList<String>();
    try{    
            int i=0;
    Class.forName("com.mysql.jdbc.Driver").newInstance();
        conn = DriverManager.getConnection(url, userName, passw);
        pst = conn.prepareStatement("");
    String sql ="select suspectname,suspectaliases,suspectht,suspectgender,features,crimeaddress,crimetype,caseno,casestatus from crimereport";
        pst.executeQuery(sql);
        rs = pst.getResultSet();
        while(rs.next()){
            datalist.add(rs.getString("suspectname"));
            datalist.add(rs.getString("suspectaliases"));
            datalist.add(rs.getString("suspectht"));
            datalist.add(rs.getString("suspectgender"));
            datalist.add(rs.getString("features"));
            datalist.add(rs.getString("crimeaddress"));
            datalist.add(rs.getString("crimetype"));
            datalist.add(rs.getString("caseno"));
            datalist.add(rs.getString("casestatus"));}
        rs.close();pst.close(); }
    catch(Exception e){System.out.println("Exception is;"+e);}
    request.setAttribute("data",datalist);
    RequestDispatcher dispatcher = request.getRequestDispatcher(page);
    if (dispatcher != null){
        dispatcher.forward(request, response);
    }
        }
}    

crimeinfo.jsp

<%@ page language="java" import="java.sql.*" import="java.util.*" 
contentType="text/html; charset=ISO-8859-1"
    pageEncoding="ISO-8859-1"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4
/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
<title>Crime Report</title>
</head>
<body>
    <table border="1" with="600">
    <tr><td><tb><td>SuspectName</td></b>
    <td><tb>SuspectAlias</b></td>
    <td><tb>suspectaliases</tb></td>
    <td><tb>Height</tb></td>
    <td><tb>suspectht</tb></td>
    <td><tb>Gender</tb></td>
    <td><tb>suspectgender</tb></td>
    <td><tb>Features</tb></td>
    <td><tb>features</tb></td>
    <td><tb>Address</tb></td>
    <td><tb>crimeaddress</tb></td>
    <td><tb>CrimeType</tb></td>
    <td><tb>crimetype</tb></td>
    <td><tb>CaseNumber</tb></td>
    <td><tb>caseno</tb></td>
    <td><tb>Status</tb></td>
    <td><tb>casestatus</tb></td></tr>
    <% Iterator <String> itr;%>
    <%List data =(List)request.getAttribute("datalist");
    for (itr = data.iterator();
    itr.hasNext();){%><tr>
    <%String s =(String)itr.next(); %>
    <td><%=itr.next()%>></td>
    <tr><td><%=itr.next()%>></td>
    <tr><td><%=itr.next()%>></td>
    <tr><td><%=itr.next()%>></td>
    <tr><td><%=itr.next()%>></td>
    <tr><td><%=itr.next()%>></td>
    <tr><td><%=itr.next()%>></td>
        <tr><td><%=itr.next()%>></td>
        <tr><td><%=itr.next()%>></td>
<tr><td><%=itr.next()%>></td>
    <tr><td><%=itr.next()%>></td>
    <tr><td><%=itr.next()%>></td>
    <tr><td><%=itr.next()%>></td>
    <tr><td><%=itr.next()%>></td>
    <tr><td><%=itr.next()%>></td>
    <tr><td><%=itr.next()%>></td>
    <tr><td><%=itr.next()%>></td></tr><%} %>
</table>
</body>
</html>

【问题讨论】:

  • 为了更好地理解这一点,第一个代码是 xml 代码 viewcrimereport.xml
  • 格式严重不佳。而“data”本身就是“datum”的复数形式。没有什么叫做“数据”
  • @user354361 我已经回答了您的问题,如果您遇到更多问题,请发表评论

标签: java jsp servlets jdbc scriptlet


【解决方案1】:
  1. 在第 32 行,将其设为 Iterator itr = data.iterator() ; 我建议您使用 while(itr.hasNext() 代替 for 循环,以使代码更清晰。此外,for 循环中的初始化部分是可重复的。

  2. 将你的 xml 文件重命名为 web.xml 并将其命名为 \WEB-INF\web.xml

  3. 在 web.xml 中,url-pattern 应该是&lt;url-pattern&gt;/viewcrimereport&lt;/url-pattern&gt;

  4. 对于你的servlet,由于你已经扩展了HttpServlet类,不需要实现Servlet接口。 HttpServlet 类已经实现了该接口

  5. 您尚未关闭连接。使用conn.close()

  6. 在你的jsp中,它应该是&lt;%List data =(List)request.getAttribute("data");,因为你已经设置了名称为data而不是“datalist”的请求属性

  7. 不鼓励使用小脚本(那些&lt;% %&gt; 的东西)。 see this

  8. 由于您没有从 servlet 向浏览器输出任何内容,因此可以省略以下代码 PrintWriter out=response.getWriter(); response.setContentType("text/html");

  9. 在我个人看来,我建议使用service 而不是doGet()。服务方法本身会调用 doGet 方法。此外,它还可以根据需要调用其他方法,如 doPost、doHead 等。

【讨论】:

  • 感谢您的帮助。我已完成您建议的所有更正并收到此错误消息。 org.apache.jasper.JasperException:在第 32 行 29:30:31 处理 JSP 页面 /crimeinfo.jsp 时发生异常: itr = data.iterator() ; 33: for (itr = data.iterator(); 34: itr.hasNext();) 35: {%>
  • 与您之前遇到的相同异常?我想你错过了我的第一点。
  • 我完全按照你的建议做了......这是代码 itr = data.iterator() ; for (itr = data.iterator(); itr.hasNext();) {%>
  • 对不起,我的错误。我忘了编辑那个。现在我已经更新了我的最佳点。
  • 我建议你为此使用 jstl 标签。
【解决方案2】:

您可以使用ArrayListdatalist.get(column index) 方法。更多详情请参考: http://www.tutorialspoint.com/java/java_arraylist_class.htm

【讨论】:

猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2013-02-11
  • 2022-01-20
  • 2022-01-24
  • 2018-08-06
相关资源
最近更新 更多