gpt4 book ai didi

java - 从数据库表中检索数据并用html将其显示在表中

转载 作者:行者123 更新时间:2023-12-02 05:55:24 25 4
gpt4 key购买 nike

我是一名初学者,目前正在完成我的期末学校项目,该项目需要从数据库表中检索数据并在 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: {%>

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

viewcrime.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>

viewcrimereport.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>

最佳答案

  1. 在第 32 行,将其设为 Iterator itr = data.iterator() ;我建议您使用while(itr.hasNext()为了使代码更加清晰,代替了 for 循环。另外,for循环中的初始化部分是多余的。

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

  3. 在 web.xml 中,url-pattern 应为 <url-pattern>/viewcrimereport</url-pattern>

  4. 对于您的 servlet,因为您已经扩展了 HttpServlet类,无需实现Servlet界面。 HttpServlet 类已经实现了该接口(interface)

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

  6. 在你的jsp中,它应该是<%List data =(List)request.getAttribute("data");因为您已设置名称为 data 的请求属性而不是“数据列表”

  7. 不鼓励使用 scriptlet(那些 <% %> 的东西)。 see this

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

  9. 以我个人的观点,我建议使用 service而不是doGet() 。 Service方法本身会调用doGet方法。另外,如果需要的话,它还可以调用其他方法,如 doPost、doHead 等。

关于java - 从数据库表中检索数据并用html将其显示在表中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23141409/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com