实现JSP用户7天内免登录:一个清晰的代码示例

在Web开发中,“记住我”或免登录功能是提升用户体验的常见需求。今天,我们就通过一个具体的JSP实例,来拆解如何实现简单的用户7天内免登录。代码清晰,步骤完整,供各位在类似项目中参考使用。

(1)登录页面:login.jsp

一切从登录页开始。这个页面的核心在于表单:它不仅要收集用户名和密码(本例中省略了密码输入以聚焦Cookie逻辑),还提供了一个“记住我”的复选框。注意看用户名输入框的value值,它尝试从名为“cook_name”的Cookie中读取,这实现了在用户再次访问时自动填充用户名。

<%@ page language="ja va" contentType="text/html; charset=utf-8"  pageEncoding="utf-8"%>




Insert title here


用户名:
记住我,7天内免登录

验证session 验证cookie

(2)跳转与验证页面:cookieUser.jsp

用户登录后,会被引导至这个页面进行Cookie验证。它的任务很明确:从请求中获取所有Cookie,然后遍历寻找我们存放用户信息的那个“cook_name”。找到了,就显示欢迎信息;找不到或者已失效,则二话不说,跳转回登录页面。这里用了一个小技巧,在判断Cookie数组非空时,把`null != cookies`写在前面,可以有效避免空指针异常。

<%@ page language="ja va" contentType="text/html; charset=utf-8"
  pageEncoding="utf-8"%>




Insert title here


<%
    //从浏览器获取cookie
   Cookie[] cookies = request.getCookies();
   String uname = null;

   //判断语句条件小技巧
   if(null != cookies){
    for(Cookie cookie:cookies){   //遍历本地浏览器中的所有cookie
   if(cookie.getName().equals("cook_name")){
    //把cookie中的用户名取出
    uname = cookie.getValue();
   }
   //out.print("

name: " + cookie.getName()+"

"); //out.print("

value: " + cookie.getValue()+"

"); } } //判断cookie有没有失效 if(null != uname){ out.print("

用户名:"+uname +"

"); } else{ response.sendRedirect("login.jsp"); } %>

(3)核心处理器:LoginServlet类

最后,也是最关键的一环——Servlet。它处理登录请求,灵魂在于Cookie的创建与设置。Servlet获取前端提交的用户名和复选框状态,然后创建一个以用户名为值的Cookie。关键是`setMaxAge`方法:如果用户勾选了“记住我”,则设置Cookie有效期为7天(3600秒 * 24小时 * 7天);如果没勾选,则使用默认值。设置完成后,通过`response`对象将Cookie写入浏览器,并重定向到验证页面。整个流程,是不是一下子就串联起来了?

package com.servlet;

import ja va.io.IOException;
import ja vax.servlet.ServletException;
import ja vax.servlet.annotation.WebServlet;
import ja vax.servlet.http.Cookie;
import ja vax.servlet.http.HttpServlet;
import ja vax.servlet.http.HttpServletRequest;
import ja vax.servlet.http.HttpServletResponse;
import ja vax.servlet.http.HttpSession;

/**
 * Servlet implementation class LoginServlet
 */
@WebServlet("/LoginServlet")
public class LoginServlet extends HttpServlet {
 private static final long serialVersionUID = 1L;

     /**
   * @see HttpServlet#HttpServlet()
   */
  public LoginServlet() {
    super();
    // TODO Auto-generated constructor stub
  }

 /**
 * @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response)
 */
 protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
 // TODO Auto-generated method stub
 //获取用户登录名
 String username = request.getParameter("username");

 //获取7天内是否免登录
 String day7 = request.getParameter("chkCookie");
 int cookie_day = 1;
 if(null != day7 && day7.equals("")){
    cookie_day = Integer.valueOf(day7);
 }

 //创建cookie
 Cookie cookie = new Cookie("cook_name",username);

 //设置Cookie有限期
 //cookie.setMaxAge(6);//有效期6秒
 cookie.setMaxAge(3600 * 24 * cookie_day);//设置7天免登录

 //写入cookie到浏览器
 response.addCookie(cookie);
 response.sendRedirect("cookieUser.jsp");

   }

 /**
 * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response)
 */
 protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
 // TODO Auto-generated method stub
 doGet(request, response);
 }
}

希望这个从界面到逻辑都完整呈现的示例,能帮助大家透彻理解JSP中基于Cookie实现免登录的机制。当然,在实际生产环境中,还需要考虑密码加密、Cookie安全性(如HttpOnly、Secure属性)等更多因素,但这里的代码无疑是一个扎实的起点。

本文转载于:https://www.jb51.net/article/180956.htm 如有侵犯,请联系zhengruancom@outlook.com删除。
免责声明:正软商城发布此文仅为传递信息,不代表正软商城认同其观点或证实其描述。