注销防止后退按钮 java 不起作用我已经尝试了一整天但仍然无法得到结果,我错过了什么?

发布于 2025-01-10 02:36:14 字数 8013 浏览 0 评论 0原文

这是我的 Java 类

package login.example;

import java.io.IOException;
import java.io.PrintWriter;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;

import javax.persistence.Id;
import javax.servlet.RequestDispatcher;
import javax.servlet.ServletContext;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;

@WebServlet("/UserOne")
public class UserOne extends HttpServlet {

    private static final long serialVersionUID = -7250065889869767422L;

    @Id
    private long id;
    private String name;

    public Long getId() {
        return id;
    }

    public void setId(Long id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public void setId(long id) {
        this.id = id;
    }

    protected void doGet(HttpServletRequest request, HttpServletResponse response)
            throws IOException, ServletException {
        PrintWriter out = response.getWriter();
        response.setContentType("text/html");
        long id = Long.parseLong(request.getParameter("id"));
        String name = request.getParameter("name");
        // String userRePass = request.getParameter("userRePassWord");

        try {
            Class.forName("com.mysql.jdbc.Driver");
            Connection con = DriverManager.getConnection("jdbc:mysql://localhost:3306/any", "root", "jaygurudev1@");
            PreparedStatement ps = con.prepareStatement("Select id,name from user where id=? and name=?");
            ps.setLong(1, id);
            ps.setString(2, name);
            ResultSet rs = ps.executeQuery();
            // HttpServletRequest request = null;
            if (rs.next()) {
                HttpSession session = request.getSession(true);
                session.setAttribute("id", id);
                session.setAttribute("name", name);
                ServletContext context = request.getServletContext();

                response.setHeader("Cache-control", "no-cache"); // HTTP 1.1
                response.setHeader("Cache-control", "no-store");
                response.setHeader("Pragma", "no-cache"); // HTTP 1.0
                response.setDateHeader("Expire", 0);
                RequestDispatcher dispatcher = context.getRequestDispatcher("/admin.jsp");
                dispatcher.forward(request, response);
                // or you can write whole thing in one line as ........

                // getServletContext().getRequestDispatcher("/success").forward(request,
                // response);

            } else {
                // request.setAttribute("wrongUser", userName);

                ServletContext context = request.getServletContext();

                response.setHeader("Cache-control", "no-cache"); // HTTP 1.1
                response.setHeader("Cache-control", "no-store");
                response.setHeader("Pragma", "no-cache"); // HTTP 1.0
                response.setDateHeader("Expire", 0);

                RequestDispatcher dispatcher = context.getRequestDispatcher("/login.jsp");
                dispatcher.forward(request, response);

                // or you can write whole thing in one line as ........
                // getServletContext().getRequestDispatcher("/fail").forward(request,
                // response);
            }

        } catch (SQLException e) {
            e.printStackTrace();
        } catch (ClassNotFoundException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }

    }

}

这是我的 login.jsp 这是

<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
    pageEncoding="ISO-8859-1"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="ISO-8859-1">
<title>Insert title here</title>
</head>
<body>
    <div style="text-align: center">
        <h1>admin login</h1>
        <%
            response.setHeader("Cache-Control", "no-cache, no-store, must-revalidate"); // HTTP 1.1
            response.setHeader("Pragma", "no-cache"); // HTTP 1.0
            response.setDateHeader("Expires", 0); // Proxies.
        %>
        <form action="/UserOne" method="get">
            <label for="id">Id</label> <input name="id" /> <label for="name">Name</label>
            <input type="text" name="name" />
            <button type="submit">Login</button>
        </form>

    </div>
</body>
</html>

我的 admin.jsp

<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
    pageEncoding="ISO-8859-1"%>
<%@page import="java.sql.DriverManager"%>
<%@page import="java.sql.ResultSet"%>
<%@page import="java.sql.Statement"%>
<%@page import="java.sql.Connection"%>
<%@page import="java.io.IOException"%>
<%@page import="java.io.PrintWriter"%>
<!DOCTYPE html>
<html>
<head>
<style>
body {
    background-image: url(/images/admin.jpg);
    background-repeat: repeat;
    background-size: 640px 640px;
}
</style>
</head>
<body>

    <%
        response.setHeader("Cache-control", "no-cache"); // HTTP 1.1
        response.setHeader("Cache-control", "no-store");
        response.setHeader("Pragma", "no-cache"); // HTTP 1.0
        response.setDateHeader("Expire", 0);
    %>
    <a href="/userone">get all users</a>
    <h3>view user</h3>

    getMobileInfo
    <a href="/indexone">get all mobile details</a>


    <form action="/LogoutServlet" method="get">
        <input type="submit" value="logout">
    </form>

</body>
</html>

这是注销 servlet

package login.example;

import java.io.IOException;
import java.io.PrintWriter;

import javax.servlet.RequestDispatcher;
import javax.servlet.ServletContext;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;

@WebServlet(name = "LogoutServlet", urlPatterns = { "/LogoutServlet" })
public class LogoutServlet extends HttpServlet {

    private static final long serialVersionUID = 1L;

    public LogoutServlet() {
    }

    protected void doGet(HttpServletRequest request, HttpServletResponse response)
            throws IOException, ServletException {

        PrintWriter out = response.getWriter();
        response.setContentType("text/html");
        HttpSession session = request.getSession();
        session.removeAttribute("id");
        session.removeAttribute("name");
        request.getSession(false);
        session.invalidate();
        out.println("Thank you,you are successfully logged out");
        // response.setHeader("Cache-Control", "no-cache,no-store,must-revalidate");

        HttpServletResponse httpResponse = (HttpServletResponse) response;
        httpResponse.setHeader("Cache-Control", "no-cache, no-store, must-revalidate"); // HTTP 1.1
        httpResponse.setHeader("Pragma", "no-cache"); // HTTP 1.0
        httpResponse.setDateHeader("Expires", 0); // Proxies.

        // request.getRequestDispatcher("login.jsp").include(request, response);
        response.sendRedirect("login.jsp");
    }

}

我应该添加或删除什么才能获得所需的输出,例如注销后不显示上一页?我的代码有什么问题吗?我是否需要任何依赖或其他东西来实现这一目标?怎么解决这个问题呢?

我的网址就像 http://localhost:8080/home.html 然后http://localhost:8080/login.jsp? 和http://localhost:8080/UserOne?id=1&name=ritu

This is my Java class

package login.example;

import java.io.IOException;
import java.io.PrintWriter;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;

import javax.persistence.Id;
import javax.servlet.RequestDispatcher;
import javax.servlet.ServletContext;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;

@WebServlet("/UserOne")
public class UserOne extends HttpServlet {

    private static final long serialVersionUID = -7250065889869767422L;

    @Id
    private long id;
    private String name;

    public Long getId() {
        return id;
    }

    public void setId(Long id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public void setId(long id) {
        this.id = id;
    }

    protected void doGet(HttpServletRequest request, HttpServletResponse response)
            throws IOException, ServletException {
        PrintWriter out = response.getWriter();
        response.setContentType("text/html");
        long id = Long.parseLong(request.getParameter("id"));
        String name = request.getParameter("name");
        // String userRePass = request.getParameter("userRePassWord");

        try {
            Class.forName("com.mysql.jdbc.Driver");
            Connection con = DriverManager.getConnection("jdbc:mysql://localhost:3306/any", "root", "jaygurudev1@");
            PreparedStatement ps = con.prepareStatement("Select id,name from user where id=? and name=?");
            ps.setLong(1, id);
            ps.setString(2, name);
            ResultSet rs = ps.executeQuery();
            // HttpServletRequest request = null;
            if (rs.next()) {
                HttpSession session = request.getSession(true);
                session.setAttribute("id", id);
                session.setAttribute("name", name);
                ServletContext context = request.getServletContext();

                response.setHeader("Cache-control", "no-cache"); // HTTP 1.1
                response.setHeader("Cache-control", "no-store");
                response.setHeader("Pragma", "no-cache"); // HTTP 1.0
                response.setDateHeader("Expire", 0);
                RequestDispatcher dispatcher = context.getRequestDispatcher("/admin.jsp");
                dispatcher.forward(request, response);
                // or you can write whole thing in one line as ........

                // getServletContext().getRequestDispatcher("/success").forward(request,
                // response);

            } else {
                // request.setAttribute("wrongUser", userName);

                ServletContext context = request.getServletContext();

                response.setHeader("Cache-control", "no-cache"); // HTTP 1.1
                response.setHeader("Cache-control", "no-store");
                response.setHeader("Pragma", "no-cache"); // HTTP 1.0
                response.setDateHeader("Expire", 0);

                RequestDispatcher dispatcher = context.getRequestDispatcher("/login.jsp");
                dispatcher.forward(request, response);

                // or you can write whole thing in one line as ........
                // getServletContext().getRequestDispatcher("/fail").forward(request,
                // response);
            }

        } catch (SQLException e) {
            e.printStackTrace();
        } catch (ClassNotFoundException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }

    }

}

This is my login.jsp

<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
    pageEncoding="ISO-8859-1"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="ISO-8859-1">
<title>Insert title here</title>
</head>
<body>
    <div style="text-align: center">
        <h1>admin login</h1>
        <%
            response.setHeader("Cache-Control", "no-cache, no-store, must-revalidate"); // HTTP 1.1
            response.setHeader("Pragma", "no-cache"); // HTTP 1.0
            response.setDateHeader("Expires", 0); // Proxies.
        %>
        <form action="/UserOne" method="get">
            <label for="id">Id</label> <input name="id" /> <label for="name">Name</label>
            <input type="text" name="name" />
            <button type="submit">Login</button>
        </form>

    </div>
</body>
</html>

This is my admin.jsp

<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
    pageEncoding="ISO-8859-1"%>
<%@page import="java.sql.DriverManager"%>
<%@page import="java.sql.ResultSet"%>
<%@page import="java.sql.Statement"%>
<%@page import="java.sql.Connection"%>
<%@page import="java.io.IOException"%>
<%@page import="java.io.PrintWriter"%>
<!DOCTYPE html>
<html>
<head>
<style>
body {
    background-image: url(/images/admin.jpg);
    background-repeat: repeat;
    background-size: 640px 640px;
}
</style>
</head>
<body>

    <%
        response.setHeader("Cache-control", "no-cache"); // HTTP 1.1
        response.setHeader("Cache-control", "no-store");
        response.setHeader("Pragma", "no-cache"); // HTTP 1.0
        response.setDateHeader("Expire", 0);
    %>
    <a href="/userone">get all users</a>
    <h3>view user</h3>

    getMobileInfo
    <a href="/indexone">get all mobile details</a>


    <form action="/LogoutServlet" method="get">
        <input type="submit" value="logout">
    </form>

</body>
</html>

This is logout servlet

package login.example;

import java.io.IOException;
import java.io.PrintWriter;

import javax.servlet.RequestDispatcher;
import javax.servlet.ServletContext;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;

@WebServlet(name = "LogoutServlet", urlPatterns = { "/LogoutServlet" })
public class LogoutServlet extends HttpServlet {

    private static final long serialVersionUID = 1L;

    public LogoutServlet() {
    }

    protected void doGet(HttpServletRequest request, HttpServletResponse response)
            throws IOException, ServletException {

        PrintWriter out = response.getWriter();
        response.setContentType("text/html");
        HttpSession session = request.getSession();
        session.removeAttribute("id");
        session.removeAttribute("name");
        request.getSession(false);
        session.invalidate();
        out.println("Thank you,you are successfully logged out");
        // response.setHeader("Cache-Control", "no-cache,no-store,must-revalidate");

        HttpServletResponse httpResponse = (HttpServletResponse) response;
        httpResponse.setHeader("Cache-Control", "no-cache, no-store, must-revalidate"); // HTTP 1.1
        httpResponse.setHeader("Pragma", "no-cache"); // HTTP 1.0
        httpResponse.setDateHeader("Expires", 0); // Proxies.

        // request.getRequestDispatcher("login.jsp").include(request, response);
        response.sendRedirect("login.jsp");
    }

}

What should I add or remove in order to get desired output such as it does not show previous page after I logged out? What is wrong with my code? Should I need any dependency or anything else to achieve this? How to solve this?

my url is like http://localhost:8080/home.html
then http://localhost:8080/login.jsp?
and http://localhost:8080/UserOne?id=1&name=ritu

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

唐婉 2025-01-17 02:36:14

当您单击后退按钮时,URL (/UserOne?id=1&name=ritu) 会提交旧的 ID 和名称,使其能够再次登录该页面。在 post 参数中发送登录凭据以解决问题。

即:在login.jsp中,提交方法应该是post

When you click back button the the url (/UserOne?id=1&name=ritu) submits the old id and name making it to login to the page again. Send the login credentials in post parameter to fix the issue.

ie: In login.jsp the submit method should be post

苏大泽ㄣ 2025-01-17 02:36:14

我在每个我想要作为安全页面的jsp页面中添加了以下代码,

<%
        if (session.getAttribute("id_name") == null && (session.getAttribute("name_name") == null)) {
            response.sendRedirect("/home.html");
        }
    %>

无需在springboot中编写以下代码,因为springboot自动添加以下代码

<%
    response.setHeader("Cache-Control", "no-cache, no-store, must-revalidate"); // HTTP 1.1
    response.setHeader("Pragma", "no-cache"); // HTTP 1.0
    response.setDateHeader("Expires", 0); // Proxies.
%>

i have added below code in every jsp page which i want as secure page

<%
        if (session.getAttribute("id_name") == null && (session.getAttribute("name_name") == null)) {
            response.sendRedirect("/home.html");
        }
    %>

no need to write this below code in springboot,as springboot automatically add below code

<%
    response.setHeader("Cache-Control", "no-cache, no-store, must-revalidate"); // HTTP 1.1
    response.setHeader("Pragma", "no-cache"); // HTTP 1.0
    response.setDateHeader("Expires", 0); // Proxies.
%>
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文