从数据库中检索数据在Java服务器页面中

huangapple go评论84阅读模式
英文:

Retrieve Data from Database in Java Server Page

问题

我试图从数据库中获取数据并在浏览器中打印出一个表格。代码位于一个 JSP 文件中。

我的输出如下所示:

从数据库中检索数据在Java服务器页面中

仍然缺少表中的值。现在我想知道为什么没有获取到表中的数据。我检查了数据,表中填充了值。

以下是带有数据的命令行输出(已模糊处理):

从数据库中检索数据在Java服务器页面中

以下是我在 JSP 文件中的代码:

<%@page contentType="text/html" pageEncoding="UTF-8"%>

<%@page import="java.sql.DriverManager"%>
<%@page import="java.sql.ResultSet"%>
<%@page import="java.sql.Statement"%>
<%@page import="java.sql.Connection"%>
<%
    String id = request.getParameter("userid");
    String driver = "com.mysql.jdbc.Driver";
    String connectionUrl = "jdbc:mysql://localhost:3306/";
    String database = "store";
    String userid = "root";
    String password = "";
    try {
        Class.forName(driver);
    } catch (ClassNotFoundException e) {
        e.printStackTrace();
    }
    Connection connection = null;
    Statement statement = null;
    ResultSet resultSet = null;
%>


<!DOCTYPE html>
<html>
    <head>
        <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
        <title>JSP Page</title>
    </head>
    <body>
        <h1>Retrieve data from database in jsp</h1>
		<table border="1">
			<tr>
				<th>Name</th>
				<th>Strasse</th>
				<th>PLZ</th>
				<th>Ort</th>
			</tr>
			
			<%
				try{
					connection = DriverManager.getConnection(connectionUrl+database, userid, password);
					statement=connection.createStatement();
					String sql ="select * from kunde";
					resultSet = statement.executeQuery(sql);
					while(resultSet.next()){
						%>
						<tr>
							<td><%=resultSet.getString("name") %></td>
							<td><%=resultSet.getString("strasse") %></td>
							<td><%=resultSet.getString("plz") %></td>
							<td><%=resultSet.getString("ort") %></td>
						</tr>
						
						<%
					}
					connection.close();
				}
				catch (Exception e) {
					e.printStackTrace();
				}
			%>
			</table>
    </body>
</html>

在日志文件中,我找到了两条以下错误消息:

在 jsp 文件中的第 [41] 行发生错误:[/index.jsp]
无法将 userid 解析为变量
38: 			
39: 			<%
40: 				try{
41: 					connection = DriverManager.getConnection(connectionUrl+database, userid, password);
42: 					statement=connection.createStatement();
43: 					String sql ="select * from kunde";
44: 					resultSet = statement.executeQuery(sql);
...

堆栈跟踪,带有根本原因
org.apache.jasper.JasperException: 无法为 JSP 编译类:

在 jsp 文件中的第 [41] 行发生错误:[/index.jsp]
无法将 userid 解析为变量
38: 			
39: 			<%
40: 				try{
41: 					connection = DriverManager.getConnection(connectionUrl+database, userid, password);
42: 					statement=connection.createStatement();
43: 					String sql ="select * from kunde";
44: 					resultSet = statement.executeQuery(sql);
...

[警告] 拒绝访问用户 'XY'@'localhost'(未使用密码)
英文:

i am trying to print out a table in the browser with fetching data from a database. The code is in a jsp-file.

My output looks the following:

从数据库中检索数据在Java服务器页面中

It is still missing the values from the table. Now i am wondering why the data from the table is not fetched. I checked the data, and the table is filled with values.

Here is my command-line output with data (blurred):
从数据库中检索数据在Java服务器页面中

This is my code in the jsp-file so far:

&lt;%@page contentType=&quot;text/html&quot; pageEncoding=&quot;UTF-8&quot;%&gt;

&lt;%@page import=&quot;java.sql.DriverManager&quot;%&gt;
&lt;%@page import=&quot;java.sql.ResultSet&quot;%&gt;
&lt;%@page import=&quot;java.sql.Statement&quot;%&gt;
&lt;%@page import=&quot;java.sql.Connection&quot;%&gt;
&lt;%
	String id = request.getParameter(&quot;userid&quot;);
	String driver = &quot;com.mysql.jdbc.Driver&quot;;
	String connectionUrl = &quot;jdbc:mysql://localhost:3306/&quot;;
	String database = &quot;store&quot;;
	String userid = &quot;root&quot;;
	String password = &quot;&quot;;
	try {
	Class.forName(driver);
	} catch (ClassNotFoundException e) {
	e.printStackTrace();
	}
	Connection connection = null;
	Statement statement = null;
	ResultSet resultSet = null;
%&gt;


&lt;!DOCTYPE html&gt;
&lt;html&gt;
    &lt;head&gt;
        &lt;meta http-equiv=&quot;Content-Type&quot; content=&quot;text/html; charset=UTF-8&quot;&gt;
        &lt;title&gt;JSP Page&lt;/title&gt;
    &lt;/head&gt;
    &lt;body&gt;
        &lt;h1&gt;Retrieve data from database in jsp&lt;/h1&gt;
		&lt;table border=&quot;1&quot;&gt;
			&lt;tr&gt;
				&lt;th&gt;Name&lt;/th&gt;
				&lt;th&gt;Strasse&lt;/th&gt;
				&lt;th&gt;PLZ&lt;/th&gt;
				&lt;th&gt;Ort&lt;/th&gt;
			&lt;/tr&gt;
			
			&lt;%
				try{
					connection = DriverManager.getConnection(connectionUrl+database, userid, password);
					statement=connection.createStatement();
					String sql =&quot;select * from kunde&quot;;
					resultSet = statement.executeQuery(sql);
					while(resultSet.next()){
						%&gt;
						&lt;tr&gt;
							&lt;td&gt;&lt;%=resultSet.getString(&quot;name&quot;) %&gt;&lt;/td&gt;
							&lt;td&gt;&lt;%=resultSet.getString(&quot;strasse&quot;) %&gt;&lt;/td&gt;
							&lt;td&gt;&lt;%=resultSet.getString(&quot;plz&quot;) %&gt;&lt;/td&gt;
							&lt;td&gt;&lt;%=resultSet.getString(&quot;ort&quot;) %&gt;&lt;/td&gt;
						&lt;/tr&gt;
						
						&lt;%
					}
					connection.close();
				}
				catch (Exception e) {
					e.printStackTrace();
				}
			%&gt;
			&lt;/table&gt;
    &lt;/body&gt;
&lt;/html&gt;

In the log-files i found two of the following error messages:

An error occurred at line: [41] in the jsp file: [/index.jsp]
userid cannot be resolved to a variable
38: 			
39: 			&lt;%
40: 				try{
41: 					connection = DriverManager.getConnection(connectionUrl+database, userid, password);
42: 					statement=connection.createStatement();
43: 					String sql =&quot;select * from kunde&quot;;
44: 					resultSet = statement.executeQuery(sql);


Stacktrace:] with root cause
org.apache.jasper.JasperException: Unable to compile class for JSP: 

An error occurred at line: [41] in the jsp file: [/index.jsp]
userid cannot be resolved to a variable
38: 			
39: 			&lt;%
40: 				try{
41: 					connection = DriverManager.getConnection(connectionUrl+database, userid, password);
42: 					statement=connection.createStatement();
43: 					String sql =&quot;select * from kunde&quot;;
44: 					resultSet = statement.executeQuery(sql);

And

[Warning] Access denied for user &#39;XY&#39;@&#39;localhost&#39; (using password: NO)

答案1

得分: 1

我解决了这个问题。
我需要将 mysql-connector-java-5.1.25-bin.jar 文件添加到我的 tomcat 的 lib 文件夹中。

英文:

I solved the problem.
I needed to add the mysql-connector-java-5.1.25-bin.jar file to my tomcat's lib.

huangapple
  • 本文由 发表于 2020年9月14日 23:52:18
  • 转载请务必保留本文链接:https://go.coder-hub.com/63887756.html
匿名

发表评论

匿名网友

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定