Cookie是以文本文件保存在客户端的.
1.创建Cookie对象
Cookie newCookie = new Cookie(String key, Object value);
2.写入Cookie对象
response.addCookie(new Cookie);
3.读取Cookie对象
Cookie[] cookies = request.getCookies();
Cookie常用方法
void setManAge(int expiry)设置cookie的有效期,单位秒
void setValue(String value) 在cookie创建后,对cookie进行赋值
String getName() 获取cookie的名称
String getValue()获取cookie的值
int getMaxAge()获取cookie的有效时间,单位秒
关于Cookie保存中文的解决办法
保存Cookie
....
request.setCharacterEncoding("utf-8");
String[] isUseCookies = request.getParameterValues("isUseCookie");
if(isUseCookies != null && isUseCookies.length >0 )
{
//把用户名和密码保存在Cookie对象里面
//使用URLEncoding解决无法在Cookie中保存的问题
String username=URLEncoder.encode(request.getParameter("username"), "utf-8");
String password=URLEncoder.encode(request.getParameter("password"), "utf-8");
Cookie usernameCookie = new Cookie("username", username);
Cookie passwordCookie = new Cookie("password", password);
usernameCookie.setMaxAge(864000);
passwordCookie.setMaxAge(864000);
response.addCookie(usenameCookie);
response.addCookie(passwordCookie);
}
读取Cookie
...
request.setCharacterEncoding("utf-8");
String username = "";
String password = "";
Cookie[] cookies = request.getCookies();
if(cookies !=null &&cookies.length >0)
{
for(Cookie c:cookies)
{
if(c.getName().equals("username"))
{
username = URLDecoder.decode(c.getValue(),"utf-8");
}
if(c.getName.equals("password"))
{
password = URLDecoder.decode(c.getValue(),"utf-8");
}
}
}
Session 与 Cookie对比
相同:都使用来保存用户信息
不同:
1.保存位置
Session在服务器内存中保存用户信息
Cookie在客户端本地保存用户信息
2.保存类型
Session保存的是Object类型
Cookie保存的是String类型
3.生命周期
Session随着会话结束,其存储的数据销毁
Cookie可以长期保存在客户端
4. 重要性
Session保存重要的信息
Cookie保存不重要的信息