笔记(cookie,session,重定向,请求转发)

今天在学习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")获取数据
*/

这里我有个疑问,就是地址是否可以写任意类型的

yH5BAAAAAAALAAAAAAOAA4AAAIMhI+py+0Po5y02qsKADs=wAAACH5BAEKAAAALAAAAAABAAEAAAICRAEAOw==

这里通过实践,用${username},可以jsp文件中显示,依次显示"zhangsan"和"zz"

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值