SSH2如何用Cookie做兩週免登陸效果-java

歡迎到我的個人域名博客:http://zhoulingyu.com


簡介

今天將會做一個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>

注意這裏配置了只對首頁過濾

如果有什麼問題,歡迎大家到微博互動。


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章