前面一片简单介绍了session和cookie的简单知识点和对比,其中提到cookie在应用中的一些功能应用,那么在这里我就来简单记录cookie在java服务端的一些操作!
(一)Cookie的写入操作
①建立一个最简单的Cookie,随着浏览器的打开而建立,随着浏览器的消失而关闭,不做任何时效、操作域、路径设置;
@RequestMapping("login")
public void UserOAuthLogin(HttpServletRequest request, HttpServletResponse response) {
try {
Cookie cookie = new Cookie("username",URLEncoder.encode("123456","UTF-8")); // 新建Cookie
response.addCookie(cookie); // 必须执行这一句
response.sendRedirect("http://www.cuiyongzhi.com");
} catch (Exception e) {
logger.error(e, e);
}
}
②建立一个有可控范围的Cookie:
// new一个Cookie对象,键值对为参数
Cookie cookie = new Cookie("key", "cookie的value值");
//如果cookie的值中含有中文时,需要对cookie进行编码,不然会产生乱码,使用
URLEncoder.encode("cookie的value值","utf-8");
// 设置Cookie最大生存时间,以秒为单位,负数的话为浏览器进程,关闭浏览器Cookie消失
cookie.setMaxAge(*24*60*60); // 一天
// 将Cookie添加到Response中,使之生效
cookie.setDomain("www.cuiyongzhi.com"); //设置cookie作用域
cookie.setPath("/");//设置cookie存储的虚拟目录
response.addCookie(cookie); //addCookie后,如果已经存在相同名字的cookie,则最新的覆盖旧的cookie
(二)读取Cookie
①方法一
@RequestMapping("loginout")
public void userLoginOut(HttpServletRequest request, @CookieValue("username") String cookieValue) {
System.out.println("==========================================="+cookieValue); //输出读取到的Cookie
request.getSession().invalidate(); //清空Session
}
②读取cookie的时候,为了方便希望封装一个函数,只要提供cookie的name,便可以获取cookie的value,带着这个想法,很容易想到将cookie封装到Map里面,于是进行下面的封装:
public static Cookie getCookieByName(HttpServletRequest request,String name){
Map cookieMap = ReadCookieMap(request);
if(cookieMap.containsKey(name)){
Cookie cookie = (Cookie)cookieMap.get(name);
return cookie;
}else{
return null;
}
}
private static Map ReadCookieMap(HttpServletRequest request){
Map cookieMap = new HashMap();
Cookie[] cookies = request.getCookies();
if(null!=cookies){
for(Cookie cookie : cookies){
cookieMap.put(cookie.getName(), cookie);
}
}
return cookieMap;
}
(三)Cookie的修改操作(重新赋值即可)
@RequestMapping("/editCookie")
public void editCookie(HttpServletRequest request,HttpServletResponse response,String name,String value){
Cookie[] cookies = request.getCookies();
if (null==cookies) {
System.out.println("没有cookie==============");
} else {
for(Cookie cookie : cookies){
if(cookie.getName().equals(name)){
System.out.println("原值为:"+cookie.getValue());
cookie.setValue(value);
cookie.setPath("/");
cookie.setMaxAge(30 * 60);// 设置为30min
System.out.println("被修改的cookie名字为:"+cookie.getName()+",新值为:"+cookie.getValue());
response.addCookie(cookie);
break;
}
}
}
}
(四)Cookie的删除操作(赋值为null即可)
@RequestMapping("/delCookie")
public void delCookie(HttpServletRequest request,HttpServletResponse response,String name){
Cookie[] cookies = request.getCookies();
if (null==cookies) {
System.out.println("没有cookie==============");
} else {
for(Cookie cookie : cookies){
if(cookie.getName().equals(name)){
cookie.setValue(null);
cookie.setMaxAge(0);// 立即销毁cookie
cookie.setPath("/");
System.out.println("被删除的cookie名字为:"+cookie.getName());
response.addCookie(cookie);
break;
}
}
}
}