java web 点着点着就死掉了_javaweb用户注销后点击浏览器返回刷新页面重复登录问题的解决方法...

最近在写一个购书网站,测试注销功能时点击浏览器返回刷新浏览器,会发现原本已经注销的用户又重新登录了

想了很久在网上也找了很多办法,不过网上给出的办法大多是用js实现注销后禁止用户点击游览器返回

这个办法虽然可行,但并不是在后台真正的解决这个问题,有一种防君子不防小人的感觉

下面把自己实现的方法记录下来

原理:

注销后点击浏览器返回刷新浏览器其实就是浏览器将原来form表单的信息重新发送了一遍

注销也就是干掉原来的session

// 注销

private void logout(HttpServletRequest request, HttpServletResponse response)

throws ServletException, IOException {

HttpSession session = request.getSession();

request.setAttribute("sessionId", session.getId());

session.removeAttribute("user");

session.invalidate();

response.sendRedirect(request.getContextPath() + "/index.jsp");

}

当注销后重定向到一个jsp页面是生成session与原来的session是不同的(jsp页面session默认是开启的)

也就是说注销后点击浏览器返回刷新的session是新的session,从这个角度出发思考解决办法

我在原来的session里放一段数据,第一次登陆能获取到这段数据,注销后原来的session没了,点击浏览器返回刷新,新的session里没有放数据,获取的值就是null

将原来的session里的数据与新的session值进行匹配,一个有值,一个为null,肯定会匹配失败,这时可以给用户友好的提示,让用户重新登录即可。

那么原来session里的数据如何在注销后(注销了原来的session就没了)保存呢?考虑在表单里增加一个隐藏域,将原来的session里的数据放在该隐藏域中,这样注销后点击浏览器返回刷新,浏览器会自动把原来session里的数据提交一遍,无需自己手动保存(事实上手动保存可能得放在servletContext应用上下文中,没试过)

有点类似于解决表单重复提交的一种办法,但是这里不能把原来的session里数据干掉,因为注销前后不是同一个session

具体如下:在login.jsp里

String token=new Random().nextLong()+"";

session.setAttribute("token", token);

%>

姓名:
密码:

在servlet中,给出友好提示并重定向到登录页面

HttpSession session = request.getSession();

//解决注销后后退刷新浏览器重复登录的问题

//给一个隐藏输入域,后台获取隐藏域的值

//注销后后退刷新浏览器会生成新的session,这样sessionToken获取为null

//这样hiddenToken.equals(sessionToken)就一定是false

String sessionToken = (String) session.getAttribute("token");

String hiddenToken = request.getParameter("token");

if (!hiddenToken.equals(sessionToken)) {

request.setAttribute("message", "您已注销,请重新登录,2秒后转向登录页面

+ request.getContextPath() + "/client/login.jsp>");

request.getRequestDispatcher("/client/message.jsp").forward(

request, response);

return;

}

测试:

登录

fe20325ce61901751aecc8dcd02f457e.png

注销后点击浏览器返回刷新,浏览器会提示是否重新发送数据

0d860ab94f609187b98b837822b69edf.png

点击重新发送

eb0a440d493ff84d36f65b2372774d24.png

这样就解决了注销后点击浏览器返回刷新用户重新登录的问题。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 这是一个简单的登录注册案例的Java代码实现,基于Servlet+JSP+JavaBean模式。 1. 创建一个User类,用于存储用户信息。 ```java public class User { private String username; private String password; public String getUsername() { return username; } public void setUsername(String username) { this.username = username; } public String getPassword() { return password; } public void setPassword(String password) { this.password = password; } } ``` 2. 创建一个UserDao类,用于处理用户信息的增删改查操作。 ```java public class UserDao { private static Map<String, User> users = new HashMap<String, User>(); public void addUser(User user) { users.put(user.getUsername(), user); } public User getUser(String username) { return users.get(username); } public boolean hasUser(String username) { return users.containsKey(username); } } ``` 3. 创建一个LoginServlet类,用于处理用户登录请求。 ```java public class LoginServlet extends HttpServlet { private static final long serialVersionUID = 1L; protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { String username = request.getParameter("username"); String password = request.getParameter("password"); UserDao userDao = new UserDao(); if (userDao.hasUser(username)) { User user = userDao.getUser(username); if (password.equals(user.getPassword())) { request.getSession().setAttribute("user", user); response.sendRedirect("welcome.jsp"); } else { request.setAttribute("errorMessage", "密码错误"); request.getRequestDispatcher("login.jsp").forward(request, response); } } else { request.setAttribute("errorMessage", "用户名不存在"); request.getRequestDispatcher("login.jsp").forward(request, response); } } } ``` 4. 创建一个RegisterServlet类,用于处理用户注册请求。 ```java public class RegisterServlet extends HttpServlet { private static final long serialVersionUID = 1L; protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { String username = request.getParameter("username"); String password = request.getParameter("password"); UserDao userDao = new UserDao(); if (userDao.hasUser(username)) { request.setAttribute("errorMessage", "用户名已存在"); request.getRequestDispatcher("register.jsp").forward(request, response); } else { User user = new User(); user.setUsername(username); user.setPassword(password); userDao.addUser(user); request.getSession().setAttribute("user", user); response.sendRedirect("welcome.jsp"); } } } ``` 5. 创建一个login.jsp页面,用于显示登录表单。 ```html <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>登录</title> </head> <body> <h1>登录</h1> <form action="login" method="post"> <label>用户名:</label> <input type="text" name="username"> <br> <label>密码:</label> <input type="password" name="password"> <br> <input type="submit" value="登录"> <br> <span style="color: red">${errorMessage}</span> </form> <a href="register.jsp">注册</a> </body> </html> ``` 6. 创建一个register.jsp页面,用于显示注册表单。 ```html <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>注册</title> </head> <body> <h1>注册</h1> <form action="register" method="post"> <label>用户名:</label> <input type="text" name="username"> <br> <label>密码:</label> <input type="password" name="password"> <br> <input type="submit" value="注册"> <br> <span style="color: red">${errorMessage}</span> </form> <a href="login.jsp">返回登录页面</a> </body> </html> ``` 7. 创建一个welcome.jsp页面,用于显示欢迎信息。 ```html <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>欢迎</title> </head> <body> <h1>欢迎 ${user.username}</h1> <a href="logout">注销</a> </body> </html> ``` 8. 创建一个LogoutServlet类,用于处理用户注销请求。 ```java public class LogoutServlet extends HttpServlet { private static final long serialVersionUID = 1L; protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { request.getSession().invalidate(); response.sendRedirect("login.jsp"); } } ``` 以上就是一个简单的登录注册案例的Java代码实现。 ### 回答2: 实现用户登录注册功能的实例代码,可以基于Servlet、JSP、JavaBean的模式。下面是一个简单的示例代码: 1. 新建一个JavaBean类User.java,包含以下属性和方法: ```java public class User { private String username; private String password; public String getUsername() { return username; } public void setUsername(String username) { this.username = username; } public String getPassword() { return password; } public void setPassword(String password) { this.password = password; } } ``` 2. 创建一个处理登录和注册的Servlet LoginServlet.java,代码示例如下: ```java @WebServlet("/login") public class LoginServlet extends HttpServlet { protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { // 获取请求参数 String username = request.getParameter("username"); String password = request.getParameter("password"); // 从数据库或其他数据源中验证用户登录信息 // 实际项目中需修改为合适的验证逻辑 if (username.equals("admin") && password.equals("123456")) { // 登录成功,创建用户实例 User user = new User(); user.setUsername(username); user.setPassword(password); // 将用户信息存储到Session中,方便其他页面使用 request.getSession().setAttribute("user", user); // 跳转到首页或其他需要登录后操作的页面 response.sendRedirect("home.jsp"); } else { // 登录失败,返回登录页面并提示错误信息 request.setAttribute("message", "用户名或密码错误"); request.getRequestDispatcher("login.jsp").forward(request, response); } } } ``` 3. 创建一个处理注册的Servlet RegisterServlet.java,代码示例如下: ```java @WebServlet("/register") public class RegisterServlet extends HttpServlet { protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { // 获取请求参数 String username = request.getParameter("username"); String password = request.getParameter("password"); // 创建用户实例并设置属性 User user = new User(); user.setUsername(username); user.setPassword(password); // 将用户信息存储到数据库或其他数据源中 // 实际项目中需修改为合适的存储逻辑 // 注册成功,将用户信息存储到Session中,方便登录后使用 request.getSession().setAttribute("user", user); // 跳转到注册成功页面或其他需要登录后操作的页面 response.sendRedirect("home.jsp"); } } ``` 以上是一个基于Servlet、JSP、JavaBean的用户登录注册功能实例的示例代码。通过LoginServlet处理用户登录请求,RegisterServlet处理用户的注册请求。在登录成功或注册成功后,将用户信息存储到Session中,方便其他页面使用。 ### 回答3: 登录注册是一个常见的功能需求,一般用于用户在系统中进行身份认证和账号管理。下面是基于JavaWeb的Servlet JSP JavaBean模式实现用户登录注册功能的示例代码。 首先,我们需要创建一个用于存储用户信息的JavaBean类,例如UserBean。该类可以包含用户名、密码等属性,并提供对应的get和set方法。 接着,我们创建一个用于处理用户登录和注册请求的Servlet类,例如UserServlet。在该类中,我们可以重写doGet和doPost方法,分别处理GET和POST请求。 在doGet方法中,我们可以处理用户登录的请求。首先,从request中获取用户输入的用户名和密码。然后,通过调用UserBean类的方法进行验证。如果验证成功,则重定向到登录成功页面;否则,返回登录失败页面。 在doPost方法中,我们可以处理用户注册的请求。首先,从request中获取用户输入的用户名和密码。然后,通过调用UserBean类的方法进行注册。如果注册成功,则重定向到注册成功页面;否则,返回注册失败页面。 接下来,我们需要创建一个用于显示登录和注册界面的JSP页面。在该页面中,用户可以输入用户名和密码,并选择登录或注册按钮。通过设置form的action属性,可以将请求发送给UserServlet。 最后,我们需要创建登录成功、登录失败、注册成功和注册失败页面。这些页面可以根据需要进行定制,例如显示一些提示信息或跳转到其他页面。 以上就是一个基于Servlet JSP JavaBean模式实现用户登录注册功能的简单例子。当然,实际的实现可能更加复杂,涉及到数据库连接、密码加密等方面的处理。但是通过这个例子,可以帮助你理解如何使用JavaWeb来实现用户登录注册功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值