jsp中的request.getParameter返回null或空字符串

时间:2020-06-09 17:05:18

标签: java sql jsp servlets

我为输入创建了一个html文本框,并希望将其连接到数据库。 但是每次我输入文本框并转到结果页面时,结果仅显示属性名称,而不显示任何元组。 我认为request.getParameter()返回null或空字符串。我做了几次尝试,但找不到任何解决方案。

这是我的代码。 这是selectTestForm.jsp

<%@ page contentType="text/html; charset=utf-8" %>
<%@ page import="java.sql.*" %>

<!DOCTYPE html>
<html>
<head>
    <title>Select the game</title>
</head>
<body>
    <p>Input opponent team</p>
    <form name="form1" method="get" action="result.jsp">
        <p>Opponent team : <input type="text" name="oppon"></p>
        <p><input type="submit" name="Submit" value="send"></p>
    </form>
</body>
</html>

这就是result.jsp

<%@ page contentType="text/html; charset=utf-8" %>
<%@ page import="java.sql.*" %>

<!DOCTYPE html>
<html>
<head>
    <title>Find the game</title>
</head>
<body>
    <table width="500" border="1">
        <tr>
            <td width="100">Game ID</td>
            <td width="100">Opponent Team</td>
            <td width="100">Start Date</td>
        </tr>
<%
    String opponent = (String) request.getParameter("oppon");

    Connection con = null;
    PreparedStatement pstmt = null;
    ResultSet rs = null;

    try{
        Class.forName("oracle.jdbc.driver.OracleDriver");
    }catch(ClassNotFoundException cnfe){
        cnfe.printStackTrace();
        System.out.println("Driver loading error");
    }
    try{
        String jdbcUrl = "jdbc:oracle:thin:@localhost:1521:xe";
        String userId = "sports_booking";
        String userPass = "jade";
        con = DriverManager.getConnection(jdbcUrl, userId, userPass);

        String sql = "select * from game where opponent=?";

        pstmt = con.prepareStatement(sql);
        pstmt.setString(1, "opponent");
        rs = pstmt.executeQuery();

        while( rs.next() ) {
            String game_id = rs.getString("game_id");
            String start_date = rs.getString("start_date");

%>
            <tr>
                <td width="100"><%= game_id %></td>
                <td width="100"><%= opponent %></td>
                <td width="100"><%= start_date %></td>
            </tr>

<%
        }

    }catch(SQLException e){
        e.printStackTrace();

        if(rs != null) {
            try {
                rs.close();
            }catch(SQLException sqle) {} 
        }
        if(pstmt != null) {
            try {
                pstmt.close();
            }catch(SQLException sqle) {}
        }
        if(con != null) {
            try {
                con.close();
            }catch(SQLException sqle) {}
        }
    }
%>

    </table>

</body>
</html>

如果您能帮助我解决问题,我将不胜感激!

1 个答案:

答案 0 :(得分:0)

问题出在第pstmt.setString(1, "opponent");行,因为您设置了一个常量"opponent"字符串而不是变量。

pstmt.setString(1, "opponent");-> pstmt.setString(1, opponent);应该可以正常工作了。