【Spring】获取Cookie和Session(@CookieValue()和@SessionAttribute())

文章目录
  • [获取 Cookie](#获取 Cookie)
    • [传统获取 Cookie](#传统获取 Cookie)
    • [简洁获取 Cookie(注解)](#简洁获取 Cookie(注解))
  • [获取 Session](#获取 Session)
    • [Session 存储和获取](#Session 存储和获取)
    • [简洁获取 Session (1)](#简洁获取 Session (1))
    • [简洁获取 Session (2)](#简洁获取 Session (2))

这是没有 Spring 的时候,用 Servlet 来获取(获取所有的 Cookie)

  • Spring MVC 是基于 Servlet API 构建的原始 Web 框架,也是在 Servlet 的基础上实现的

    @RequestMapping("/getcookie")

    public String getCookie(HttpServletRequest request,

    HttpServletResponse response) {

    //String name = request.getParameter("name");

    Cookie cookies[] = request.getCookies();

    if (cookies != null) {

    //将 Cookie 转成了数据流,然后进行循环

    Arrays.stream(cookies).forEach(ck -> System.out.println

    (ck.getName() + ":" + ck.getValue()));

    }

    return "获取Cookie成功";

    }

  • HttpServletRequest 代表 HTTP 的请求,HTTP 请求里面有什么,这个对象里面就有什么

  • HttpServletResponse 代表 HTTP 的响应,HTTP 响应里面有什么,这个对象里面就有什么

    这两个对象属于 Spring 的内置对象,需要就加上,不用就不用写

Cookie 是一个数组,所以进行循环打印


进入网页后,Cookie 可以直接进行修改(F12)。然后在里面添加信息,name=bitevalue=666,随后保存

之后刷新,可在服务端看到 Cookie 信息

  • Spring MVC 是基于 Servlet API 构建的原始 Web 框架,也是在 Servlet 的基础上实现的
  • HttpServletRequestHttpServletResponseServlet 提供的两个类,是 Spring MVC 方法的内置对象,需要时直接在方法中添加声明即可
  • HttpServletRequest 对象代表客户端的请求,当客户端通过 HTTP 协议访问服务器时,HTTP 请求头中的所有信息都封装在这个对象中,通过这个对象提供的方法,可以获得客户端请求的所有信息
  • HttpServletResponse 对象代表服务器的响应。HTTP 响应的信息都在这个对象中,比如向客户端发送的数据,响应头,状态码等。通过这个对象提供的方法,可以获得服务器响应的所以内容
  • Spring MVC 在这两个对象的基础上进行封装,给我们提供更加简单的使用方法

简洁获取 Cookie(注解)

Spring MVC 在这两个对象的基础上进行封装,给我们提供更加简单的使用方法

上面获取的话,就是获取的所有的 Cookie,而如果想要获取某个 Cookie,就需要使用 @CookieValue

复制代码
@RequestMapping("/getcookie2")  
public String getCookie2(@CookieValue("bite") String bite) {  
    return "从Cookie中获取值, bite:"+bite;  
}

@CookieValue 里面的值,就是你要获取的 Cookie

获取 Session

Session 存储和获取

传统方式也是用 Servlet 进行实现的

复制代码
@RequestMapping("/getsession")  
public String getsession(HttpServletRequest request) {  
    //从 Cookie 中获取到了 SessionId,根据 Session 获取 Session对象  
    HttpSession session = request.getSession();  
    String name = (String) session.getAttribute("name");  
    return "从session中获取name:"+name;  
}
  • 第四行是从 Cookie 中获取到 SessionId,然后根据 SessionId 获取到 Session 对象
  • 然后通过 getAttribute 来获取你要拿的值

因为 session 是在服务器中进行存储的,所以就不能像前面 Cookie 一样可以直接"伪造"了。就需要学习如何设置 session

复制代码
@RequestMapping("/setsession")  
public String setSession(HttpServletRequest request){  
    //从 Cookie 中获取到了SessionId,根据 SessionId 获取Session对象
    //如果没有获取到,就会创建一个Session对象  
    HttpSession session = request.getSession();  
    session.setAttribute("name","zhangsan");  
    return "设置session成功";  
}
  • 首先是在 Cookie 中获取 SessionId,然后根据 SessionId 获取 Session 对象。如果没有获取到,就会创建一个 Session 对象
  • 创建好 Session 之后,就可以进行设置了
    • 使用 setAttribute 进行设置,前面是 name,后面是 value

可以通过 Fiddler 进行观察

之后就可以通过 SessionId 获取到 Session 的值了

如果擅自将下面的 SessionId 改了,就获取不到 Session


简洁获取 Session (1)

封装一些冗余的过程

复制代码
@RequestMapping("/getsession2")  
public String getsession2(HttpSession session){  
    String name = (String) session.getAttribute("name");  
    return "从session中获取name"+name;  
}
  • 这里 HttpSession 就直接省略了自己 getSession 的过程,直接就给我们提供了一个 Session

简洁获取 Session (2)

更进一步,能直接给到我们想要的 name 的值吗

复制代码
@RequestMapping("/getsession3")  
public String getsession3(@SessionAttribute("name") String name){  
    //String name = (String) session.getAttribute("name");  
    return "从session中获取name:"+name;  
}
  • 这里的 @SessionAttribute 里面的值就是想要获取的 Session 的值,省略掉了指定 name 的步骤

我的博客即将同步至腾讯云开发者社区,邀请大家一同入驻:https://cloud.tencent.com/developer/support-planinvite_code=33sw7qvy0ds04

相关推荐
舒一笑1 小时前
为什么where=Version就是乐观锁了?
后端·mysql·程序员
GoGeekBaird1 小时前
关于垂类AI应用落地行业的方法论思考
后端·github·agent
小宁爱Python2 小时前
Django 基础入门:命令、结构与核心配置全解析
后端·python·django
老华带你飞2 小时前
考研论坛平台|考研论坛小程序系统|基于java和微信小程序的考研论坛平台小程序设计与实现(源码+数据库+文档)
java·vue.js·spring boot·考研·小程序·毕设·考研论坛平台小程序
CHEN5_022 小时前
leetcode-hot100 11.盛水最多容器
java·算法·leetcode
songx_992 小时前
leetcode18(无重复字符的最长子串)
java·算法·leetcode
你的人类朋友2 小时前
认识一下Bcrypt哈希算法
后端·安全·程序员
tangweiguo030519873 小时前
基于 Django 与 Bootstrap 构建的现代化设备管理平台
后端·django·bootstrap
在路上`3 小时前
前端学习之后端java小白(三)-sql外键约束一对多
java·前端·学习
IT果果日记3 小时前
详解DataX开发达梦数据库插件
大数据·数据库·后端