简介
今天将会做一个Cookie的Demo,也是我今天在写项目时刚刚学的小技术,这里将会展示最简单的实现Cookie的方法,以及JAVAEE中Cookie的使用。
Demo
需要注意的时,这里贴出的源码是我项目中的一部分,不需要大家具体理解其中一些变量的意思,只需要关注Cookie部分。
流程
点击页面中登录,链接到登录action
登录时选中“两周免登陆”选框,输入用户名密码,点击登录
存入Cookie
下次无需登录
登录页面表单
<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代码
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30
|
public String login() {
HttpServletResponse response = ServletActionContext.getResponse(); if (userDao.login(username, password) == null) { return ERROR; } else { session.put("user", userDao.login(username, password)); if(useCookie != null){ Cookie cookie = new Cookie("userCookie", username+"&"+password); cookie.setMaxAge(2*7*24*60*60); response.addCookie(cookie); } return SUCCESS; } }
|
注意这里useCookie是一个字符串,就是从页面表单中接收的单选框的value。 这里做的就是如果勾了选框,则保存Cookie,不选中就不保存。
相应的struts.xml中配置
1 2 3 4 5
| <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检测
1 2 3 4 5 6 7 8 9 10 11 12
|
public String cookieDetection() { if (session.get("user") != null) { return SUCCESS; } else { return LOGIN; } }
|
相应的struts.xml中配置
1 2 3 4 5
| <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,所以最好选择过滤器。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66
| 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;
public class CookieFilter implements Filter {
protected FilterConfig config;
public void init(FilterConfig config) { this.config = config; }
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; } }
|
过滤器配置
1 2 3 4 5 6 7 8
| <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>
|
注意这里配置了只对首页过滤
有什么问题都可以在博文后面留言,或者微博上私信我。
博主是 iOS 妹子一枚。
希望大家一起进步。
我的微博:Lotty周小鱼