需要保存用户信息
简介:cookie是客户端技术,服务器把每个用户的数据以cookie的形式写给用户各自的浏览器。当再次访问服务器中的web资源时,就会带着各自的数据去。这样web资源处理的就是各自的数据
细节:如果有cookie,http请求会把当前的web应用的cookie带过去。
创建cookie的基本语法
- String val=java.net.URLEncoder.encode("张家骏","utf-8");
- //创建Cookie
- Cookie cookie=new Cookie("uname",val);
- //设置cookie的生命周期,单位秒
- cookie.setMaxAge(60);
- //把cookie信息回写给浏览器
- response.addCookie(cookie);
读取cookie的代码实现
- //读取cookie
- Cookie[] cookies=request.getCookies();
- if(cookies!=null){
- for(Cookie cookie2:cookies){
- if(cookie2.getValue().equals("uname")){
- String val=java.net.URLEncoder.encode(cookie2.getValue(),"utf-8");
- out.println(val);
- }
- }
- }else{
- out.println("没有cookie");
- }
Cookie可以用来做什么?
简单举一些常用功能:
1.保存上次登录时间信息。
2.保存用户名和密码
3.记录用户访问网站的喜好(自定义背景色等)
4.网页个性化
补充一下:
cookie存储中文值乱码解决方法代码实现:
//先将要储存的值转一下类型再存入
String val=java.net.URLEncoder.encode("旺财","utf-8");
//读取时将cookie的值再转一下
String val=java.net.URLEncoder.encode(cookie2.getValue(),"utf-8");
Cookie的小结:
1.cookie在服务器端创建
2.保存在服务器端
3.生命周期可以用setMaxAge()设置,如果不设置setMaxAge(),则cookie的生命周期当浏览器关闭时消亡
4.cookie可以被多个浏览器共享
5.cookie像是一张表,两个列,名字不能重复,否则后者覆盖前者
6.cookie存放时以明文方式存放,安全性较低,可以通过加密后保存,例如md5算法
补讲md5算法:密码通过md5算法进行加密存放,验证时通过md5算法加密后再验证,对比的是两个加密后的字符串。
cookie的细节:
1.一个浏览器最多放300个cookie,每个站点最多放20个,每个cookie大小限制4kb。
2.cookie 生命周期再说明:
1.cookie的默认生命周期是会话级别
2.通过setMaxAge()可以设置生命周期
3.setMaxAge(0)可以删除cookie。设为负数说明是会话级别
cookie.setMaxAge(0);
response.add(cookie);
特别说明:如果该web应用只有一个cookie,则删除cookie后,临时文件夹中的cookie文件也删除,如果该应用有多个cookie,则文件还在,指定cookie被删 除。