/**
* Copyright © 2012-2013 <a href="https://github.com/thinkgem/jeesite">JeeSite</a> All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
*/
package com.fang.bbks.common.utils;
import java.io.UnsupportedEncodingException;
import java.net.URLDecoder;
import java.net.URLEncoder;
import javax.servlet.http.Cookie;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.apache.http.HttpResponse;
import com.fang.bbks.common.constant.ApplicationCanstant;
import com.fang.bbks.modules.sys.entity.User;
/**
* Cookie工具类
* @author ThinkGem
* @version 2013-01-15
*/
public class CookieUtils {
/**
* 设置用户信息
* @param response
* @param name
* @param pwd
* @param uid
*/
public static void setUser(HttpServletResponse response, String name,String pwd,String uid){
setCookie(response, ApplicationCanstant.COOKIE_USER_NAME, name);
setCookie(response, ApplicationCanstant.COOKIE_USER_PWD, pwd);
setCookie(response, ApplicationCanstant.COOKIE_USER_ID, uid);
}
/**
*
* !!!Exception!!!
* 跨浏览器时,会出现异常
*
* 读取cookies用户信息
* @param request
* @return
*/
public static User getUser(HttpServletRequest request){
User u = new User();
String is = getCookie(request, ApplicationCanstant.COOKIE_USER_ID);
if(is == null || "".equals(is)){
return null;
}
try{
u.setId(Long.parseLong(is));
}catch(NumberFormatException e){
return null;
}
u.setUsername(getCookie(request, ApplicationCanstant.COOKIE_USER_NAME));
u.setPassword(getCookie(request, ApplicationCanstant.COOKIE_USER_PWD));
return u;
}
/**
* 设置 Cookie(生成时间为1天)
* @param name 名称
* @param value 值
*/
public static void setCookie(HttpServletResponse response, String name, String value) {
setCookie(response, name, value, 60*60*24);
}
/**
* 设置 Cookie
* @param name 名称
* @param value 值
* @param maxAge 生存时间(单位秒)
* @param uri 路径
*/
public static void setCookie(HttpServletResponse response, String name, String value, int maxAge) {
Cookie cookie = new Cookie(name, null);
cookie.setMaxAge(maxAge);
try {
cookie.setValue(URLEncoder.encode(value, "utf-8"));
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
response.addCookie(cookie);
}
/**
* 获得指定Cookie的值
* @param name 名称
* @return 值
*/
public static String getCookie(HttpServletRequest request, String name) {
return getCookie(request, null, name, false);
}
/**
* 获得指定Cookie的值,并删除。
* @param name 名称
* @return 值
*/
public static String getCookie(HttpServletRequest request, HttpServletResponse response, String name) {
return getCookie(request, response, name, true);
}
/**
* 获得指定Cookie的值
* @param request 请求对象
* @param response 响应对象
* @param name 名字
* @param isRemove 是否移除
* @return 值
*/
public static String getCookie(HttpServletRequest request, HttpServletResponse response, String name, boolean isRemove) {
String value = null;
Cookie[] cookies = request.getCookies();
if (cookies != null) {
for (Cookie cookie : cookies) {
if (cookie.getName().equals(name)) {
try {
value = URLDecoder.decode(cookie.getValue(), "utf-8");
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
if (isRemove) {
cookie.setMaxAge(0);
response.addCookie(cookie);
}
}
}
}
return value;
}
}