今天在学习Cookie和Session的时候,在使用方法的时候,用请求转发或者是重定向的时候,被搞懵了,自己的思绪全乱了,为此,写了这个文章来理一下自己的思路。
首先Cookie是数据保存在客户端,而Session是保存在服务端。
//发送cookie
//创建cookie对象
Cookie cookie = new Cookie("key","value");
//发送cookie,response
response.addCookie(cookie);
这里是通过响应客户端的请求,把cookie存放到客户端中。
//获取Cookie
//获取Cookie数组 用request对象
Cookie[] cookies = request.getCookies();
//遍历数组
for(Cookie cookie : cookies){
//获取数据
String name = cookie.getName();
if("key".equals(name)){
String value = cookie.getValue();
System.out.println(value);
break;
}
因为cookie的存活时间到浏览器关闭的那一刻,所以可以用以下的方法设置存活时间(单位:秒)
cookie.setMaxAge(int seconds);
其次Session是将数据保存在服务端,用以下方法
//获取对象
HttpSession session = request.getSession();
//功能
void setAttribute(String name,Object o);//存储数据到session域中
Object getAttribute(String name);//根据key,获取值
void removeAttribute(String name);//根据key,删除键值对
Session在服务器正常关闭后,tomcat会自动将Session数据写入硬盘文件中,一半默认30分钟后销毁。可以用session对象的invalidate()设置销毁时间。
这里选择cookie和session全看需求
随后就是我感觉比较绕的数据共享,目前我学到的方法是重定向和请求转发两种。
首先是重定向,这里存储数据,只能用session或cookie,而不能用request域
//获取session对象
HttpSession session = request.getSession();
//存储数据
session.setAttribute("user", user);
//重定向
String contextPath = request.getContextPath();
response.sendRedirect(contextPath + "/我是地址");
/*
随后可以在重定向的地址中,通过session的getAttribute("user")方法获取存入的数据
*/
其次如果用的是请求转发的话,则要用request域,没必要用cookie和session
request.setAttribute("key","value");
//请求转发
request.getRequestDispatcher("/转发地址").forward(request, response);
/*
随后可以在请求转发的文件中,通过request.getAttribute("key")获取数据
*/
这里我有个疑问,就是地址是否可以写任意类型的
这里通过实践,用${username},可以jsp文件中显示,依次显示"zhangsan"和"zz"