jsp实现简单用户登录(用户7天内免登录)

(1)登陆页面:login.jsp

<%@ page language="java" contentType="text/html; charset=utf-8"
    pageEncoding="utf-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>Insert title here</title>
</head>
<body>
<form action="LoginServlet" method="post">
    用户名:<input type="text" name="username" value="${cookie.cook_name.value }"/><br/>
    <input type="checkbox"  name="chkCookie" value="7"/>记住我,7天内免登录<br/>
    <input type="submit" value="登录"/><br/>
    <a href="sessionUser.jsp">验证session</a>
    <a href="cookieUser.jsp">验证cookie</a>
</form>
</body>
</html>

(2)跳转页面:cookieUser.jsp

<%@ page language="java" contentType="text/html; charset=utf-8"
    pageEncoding="utf-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>Insert title here</title>
</head>
<body>
<% 
      //从浏览器获取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("<p>name: " + cookie.getName()+"</p>");
    		//out.print("<p>value: " + cookie.getValue()+"</p>");
    			
    		}
    	  
    	  }
      //判断cookie有没有失效
     if(null != uname){
    	out.print("<p>用户名:"+uname +"</p>");
     }
     else{
    	 response.sendRedirect("login.jsp");
     }
%>
</body>
</html>

(3)Servlet文件:LoginServlet类

package com.servlet;

import java.io.IOException;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.Cookie;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.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);
	}

}

完成七天登录功能,通常是指用户在首次登录之后,系统能够在之后的七天内记住用户登录状态,无需用户再次输入账号和密码进行登录。在Web应用中,这通常是通过Cookie和Session来实现的。这里提供一个简单Servlet实现思路: 1. 用户首次登录时,服务器生成一个唯一标识(如UUID),并将其存储在Cookie中。同时,服务器在后台的Session中保存这个唯一标识和用户的相关信息。 2. 用户再次访问网站时,会携带之前保存的Cookie信息。服务器检查Cookie中的唯一标识,并在后台的Session中查找是否有对应的会话信息。 3. 如果找到了对应的Session信息,并且该Session尚未失效(如在七天之内),则认为用户已经登录,服务器将用户导向之前登录后的页面。 4. 如果Cookie中没有唯一标识,或者对应的Session已经失效,则重定向用户登录页面。 以下是一个简化版的Servlet代码示例: ```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 ("正确的用户名".equals(username) && "正确的密码".equals(password)) { // 登录成功,生成唯一标识并存入Cookie和Session String uniqueToken = UUID.randomUUID().toString(); Cookie cookie = new Cookie("loginToken", uniqueToken); cookie.setMaxAge(7 * 24 * 3600); // 设置Cookie有效期为7天 response.addCookie(cookie); // 假设这里是存储Session的代码 request.getSession().setAttribute("user", username); // 登录成功后重定向到首页 response.sendRedirect("home.jsp"); } else { // 登录失败,显示错误信息 request.setAttribute("errorMessage", "用户名或密码错误"); request.getRequestDispatcher("login.jsp").forward(request, response); } } } @WebServlet("/checkLogin") public class CheckLoginServlet extends HttpServlet { protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { Cookie[] cookies = request.getCookies(); if (cookies != null) { for (Cookie cookie : cookies) { if ("loginToken".equals(cookie.getName())) { String token = cookie.getValue(); // 假设这里是检查Session的代码 if (request.getSession().getAttribute("user") != null) { // 如果Session中存在用户信息且Cookie有效,则表示用户登录 response.sendRedirect("home.jsp"); return; } } } } // 如果没有有效的Cookie或Session,则重定向到登录页面 response.sendRedirect("login.jsp"); } } ```
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值