java - 使用jsp和servlet删除表行

标签 java jsp servlets web

大家好,希望你们度过愉快的一天,因为我不是 xD,我是网络编程的新手,我已经开始使用 JSP 和 Servelt 进行网络操作,我的问题是当我单击“删除”时它触发了 servlet,但什么也没发生,该行没有被删除,并且值( pw.print(name) )没有显示。这些是我的代码。

DeleteServlet.java

import java.io.IOException;
import java.io.PrintWriter;
import java.sql.Connection;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.logging.Level;
import java.util.logging.Logger;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
public class deleteuser extends HttpServlet {

@Override
protected void doGet(HttpServletRequest request, HttpServletResponse response)
        throws ServletException, IOException {
    PrintWriter pw=response.getWriter();
    try {

        Connection con=Connecter.obtenirconnexion();
        Statement st=con.createStatement();
        String name=request.getParameter("id");
        String Query="delete from users where name ='"+ name+"'";
        st.executeUpdate(Query);
        pw.print(name);


    } catch (SQLException ex) {
        Logger.getLogger(deleteuser.class.getName()).log(Level.SEVERE, null, ex);
    }
     request.getRequestDispatcher("users.jsp").forward(request, response);


}
@Override
public String getServletInfo() {
    return "Short description";
}// </editor-fold>

}

Users.jsp

<%@page import="java.sql.ResultSet"%>
<%@page import="java.sql.PreparedStatement"%>
<%@page import="login.Connecter"%>
<%@page import="java.sql.Connection"%>
<%@page contentType="text/html" pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
    <title>Users</title>
    <style> table,td,th
        {
            border:1px black solid;
        } </style>
</head>
<body>
    <h1>Hello World</h1>
    <%
        Connection con = Connecter.obtenirconnexion();
        String req = "select * from users";
        PreparedStatement pst = con.prepareStatement(req);
        ResultSet cur = pst.executeQuery();
        out.println("<table ><tr><th>Name</th> <th>Password </th><th>Rank         </th><th>Delete </th>");
        while (cur.next()) {
            out.println("<tr><td>" + cur.getString(1) + "</td><td>" + cur.getString(2) + "</td><td>" + cur.getString(3) + "</td><td> <a href=deleteuser id='"+cur.getString(1)+"'> delete </a></td></tr>");
        }
        out.println("</table>");
        out.close();
    %>       
</body>

最佳答案

好吧,DeleteServlet 的链接已损坏。为了传递请求参数,应该是:

<a href=deleteuser?id='"+cur.getString(1)+"'> delete </a>

(注意)

但是你的做法很糟糕。

  • 您可以在 JSP 中直接访问数据库。最佳实践建议在 servlet 中进行数据访问,该 servlet 将填充请求属性并转发到 JSP 以显示所有内容(甚至具有可以进行单元测试的层:Servlet <-> 服务 <-> 持久性)
  • 在转发到 JSP 之前,您在 servlet 内执行 response.getWriter().print(...)。您打印的内容将在正文部分之外(甚至在头部之前!):这里您应该再次将其放入请求属性中并在 JSP 中使用它
  • 您使用 GET 请求来更改数据库值。 GET 请求只能用于只读操作。删除应该使用 POST 请求 - 最后一部分主要是针对纯粹主义者的,如果这是唯一的问题,我什至不会提到它......

关于java - 使用jsp和servlet删除表行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35605778/

相关文章:

java.lang.IllegalArgumentException : The servlets named [A] and [A] are both mapped to the url-pattern [/testurl] which is not permitted 异常

java servlet 通过 HTTP 连接提供文件服务

java - 无法在 Spring Boot 中拦截和操作 HttpServletResponse

java - 检测并解码图像中的多个二维(Datamatrix、QRcode)

java - 使用 ArrayList 的 android java insertsort

java - AJAX调用java方法

Java/JDBC/Sybase 登录失败 - JZ00L

javascript - 使用 JavaScript 转义单引号

apache - 域重定向后在基于 Jsp-Servlet 的应用程序中丢失 session

java - Servlet - 如何 include() 资源并以字符串形式获取其响应?