实现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
(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属性)等更多因素,但这里的代码无疑是一个扎实的起点。