前面一片简单介绍了session和cookie的简单知识点和对比,其中提到cookie在应用中的一些功能应用,那么在这里我就来简单记录cookie在java服务端的一些操作!
(一)Cookie的写入操作
①建立一个最简单的Cookie,随着浏览器的打开而建立,随着浏览器的消失而关闭,不做任何时效、操作域、路径设置;
@RequestMapping("login")
public void UserOAuthLogin(HttpServletRequest request, HttpServletResponse response) {try {Cookie cookie = new Cookie("username",de("123456","UTF-8")); // 新建Cookieresponse.addCookie(cookie); // 必须执行这一句response.sendRedirect("");} catch (Exception e) {(e, e);}}
②建立一个有可控范围的Cookie:
// new一个Cookie对象,键值对为参数 Cookie cookie = new Cookie("key", "cookie的value值"); //如果cookie的值中含有中文时,需要对cookie进行编码,不然会产生乱码,使用de("cookie的value值","utf-8"); // 设置Cookie最大生存时间,以秒为单位,负数的话为浏览器进程,关闭浏览器Cookie消失 cookie.setMaxAge(*24*60*60); // 一天 // 将Cookie添加到Response中,使之生效 cookie.setDomain("www.cuiyongzhi"); //设置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); //输出读取到的Session().invalidate(); //清空Session }
②读取cookie的时候,为了方便希望封装一个函数,只要提供cookie的name,便可以获取cookie的value,带着这个想法,很容易想到将cookie封装到Map里面,于是进行下面的封装:
public static Cookie getCookieByName(HttpServletRequest request,String name){Map cookieMap = ReadCookieMap(request);ainsKey(name)){Cookie cookie = ((name);return cookie;}else{return null;} }private static Map ReadCookieMap(HttpServletRequest request){ Map cookieMap = new HashMap();Cookie[] cookies = Cookies();if(null!=cookies){for(Cookie cookie : cookies){cookieMap.Name(), cookie);}}return cookieMap; }
(三)Cookie的修改操作(重新赋值即可)
@RequestMapping("/editCookie")public void editCookie(HttpServletRequest request,HttpServletResponse response,String name,String value){Cookie[] cookies = Cookies();if (null==cookies) {System.out.println("没有cookie==============");} else {for(Cookie cookie : cookies){Name().equals(name)){System.out.println("原值为:"Value());cookie.setValue(value);cookie.setPath("/");cookie.setMaxAge(30 * 60);// 设置为30minSystem.out.println("被修改的cookie名字为:"Name()+",新值为:"Value());response.addCookie(cookie);break;}}}}
(四)Cookie的删除操作(赋值为null即可)
@RequestMapping("/delCookie")public void delCookie(HttpServletRequest request,HttpServletResponse response,String name){Cookie[] cookies = Cookies();if (null==cookies) {System.out.println("没有cookie==============");} else {for(Cookie cookie : cookies){Name().equals(name)){cookie.setValue(null);cookie.setMaxAge(0);// 立即销毁cookiecookie.setPath("/");System.out.println("被删除的cookie名字为:"Name());response.addCookie(cookie);break;}}}}
对Cookie的简单操作基本就是这些,如有问题可以留言讨论,感谢查阅!
分享 收藏 纠错 推荐文章已发表评论数(0)
没有更多评论了^^ 更多评论 评论加载失败, 重新加载转载于:.html
本文发布于:2024-01-27 17:06:46,感谢您对本站的认可!
本文链接:https://www.4u4v.net/it/17063464041556.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
留言与评论(共有 0 条评论) |