SSH2如何用Cookie做两周免登陆效果-java

本文介绍如何在JAVAEE项目中使用Cookie实现用户两周内无需重新登录的功能,包括页面表单设计、登录逻辑处理、Cookie存储与检测,以及首页过滤器的实现。

简介

今天将会做一个Cookie的Demo,也是我今天在写项目时刚刚学的小技术,这里将会展示最简单的实现Cookie的方法,以及JAVAEE中Cookie的使用。

Demo

需要注意的时,这里贴出的源码是我项目中的一部分,不需要大家具体理解其中一些变量的意思,只需要关注Cookie部分。

流程

  1. 点击页面中登录,链接到登录action
  2. 登录时选中“两周免登陆”选框,输入用户名密码,点击登录
  3. 存入Cookie
  4. 下次无需登录

登录页面表单

<form class="registed" action="User_login" method="post">
<h2>登陆</h2>
<div class="email">
    <strong>用户名</strong><sup class="surely">*</sup><br />
<input type="text" name="username" value="" />
</div>
<div class="password">
    <strong>密码</strong><sup class="surely">*</sup><br />
<input type="password" name="password" value="" />
    <a class="forgot" href="#">忘记密码?</a>
</div>
<!-- .password -->
<div class="remember">
<input class="niceCheck" type="checkbox" name="useCookie"  value="true"/>
    <span class="rem">两周免登陆</span>
</div>
<!-- .remember -->

<div class="submit">
    <input type="submit" value="登陆" />
</div>
    <!-- .submit -->
</form>

注意action为User_login

action代码

/**
 * 用户登陆
 * 
 * @return
 */
public String login() {
    /**
     * 获取response
     */
    HttpServletResponse response = ServletActionContext.getResponse();
    //如果查询为空
    if (userDao.login(username, password) == null) {
        return ERROR;
    }
    //如果用户存在 
    else {
        //将用户放到session中
        session.put("user", userDao.login(username, password));
        //如果useCookie不为空
        if(useCookie != null){
            //新建一个Cookie,存放用户名和密码,用&做分隔符
            Cookie cookie = new Cookie("userCookie", username+"&"+password);
            //设置Cookie的存活时间(这里是两周)
            cookie.setMaxAge(2*7*24*60*60);
            //添加Cookie
            response.addCookie(cookie);
        }
        return SUCCESS;
    }
}

注意这里useCookie是一个字符串,就是从页面表单中接收的单选框的value。 这里做的就是如果勾了选框,则保存Cookie,不选中就不保存。

相应的struts.xml中配置

<action name="User_login" class="com.webstore.action.UserAction"
        method="login">
    <result name="success">/index.jsp</result>
    <result name="error">/login.jsp</result>
</action>

这里附加一个方法,用于在点击登录连接时进行Cookie检测

/**
 * 登录前检查cookie
 * 
 * @return
 */
public String cookieDetection() {
    if (session.get("user") != null) {
        return SUCCESS;
    } else {
        return LOGIN;
    }
}

相应的struts.xml中配置

<action name="User_cookieDetection" class="com.webstore.action.UserAction"
        method="cookieDetection">
    <result name="success">/index.jsp</result>
    <result name="login">/login.jsp</result>
</action>

首页过滤器

Cookie在什么时候检查呢,正常的设想是,在首页时就检查好是否有用户已经“两周免登陆”,那么需要有一个东西能够做到这一点,一般能想到的两个机制,过滤器和监听器。 监听器智能监听相应的动作,然后同时进行操作,而过滤器可以直接对request和response进行过滤,在Cookie的使用中会用到response和request,所以最好选择过滤器。

import java.io.IOException;
import java.util.Map;

import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.http.Cookie;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.apache.struts2.ServletActionContext;

import com.webstore.dao.IUserDao;
import com.webstore.imp.UserImp;

/**
 * 作者:周凌宇 时间:2014-7-4 描述:Cookie过滤器
 */
public class CookieFilter implements Filter {

    /**
     * 配置对象
     */
    protected FilterConfig config;

    /**
     * 初始化过滤器
     */
    public void init(FilterConfig config) {
        this.config = config;
    }

    /**
     * 重写doFilter方法,过滤所有请求和回复,加入或取出Cookie
     */
    public void doFilter(ServletRequest req, ServletResponse resp,
            FilterChain chain) throws IOException, ServletException {

        HttpServletRequest request = (HttpServletRequest) req;
        HttpServletResponse response = (HttpServletResponse) resp;
        Cookie[] cookies = request.getCookies();
        IUserDao userDao = new UserImp();
        String[] info = null;
        if (cookies != null) {
            for (Cookie c : cookies) {
                info = c.getValue().split("&");
                if (info.length == 2) {
                    String username = info[0];
                    String password = info[1];
                    request.getSession().setAttribute("user", userDao.login(username, password));
                }
            }
        }
        chain.doFilter(request, response);
    }

    /**
     * 销毁过滤器
     */
    public void destroy() {
        this.config = null;
    }
}

过滤器配置

<filter>
    <filter-name>CookieFilter</filter-name>
    <filter-class>com.webstore.util.CookieFilter</filter-class>
</filter>
<filter-mapping>
    <filter-name>CookieFilter</filter-name>
    <url-pattern>/index.jsp</url-pattern>
</filter-mapping>

注意这里配置了只对首页过滤

如果有什么问题,欢迎大家到微博互动。


版权声明:本文为博主原创文章,未经博主允许不得转载。

转载于:https://www.cnblogs.com/coderfish/p/4875473.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值