Springboot使用Cookie,生成cookie,获取cookie信息(注解与非注解方式)

最近无意间发现好多人搬了这个简单的cookie使用文章,大家搬文章的时候,可以先跟我说一声,互相尊重下。 不过知识分享推广这个是好的!欢迎大家一起分享!

做了个简简单单的小例子去记录一下,怎么使用这个Cookie,虽然现在用了shiro去管控登录,里面用的是token,但是说不定以后得用上这个。

废话不多说,开始上! 代!码!

先 创建一个控制类吧, 其实我没有分层啊,随便做个例子:

MyGetCookieController:

@RestController
public class MyGetCookieController {

  //......先空着-JCccc

}


//首先,想要获取Cookie信息,那么就得先有Cookie信息,这边我们自己从头开始,先弄个Cookie吧。

@RequestMapping(value = "/setCookies",method = RequestMethod.GET)
    public  String setCookies(HttpServletResponse response){
        //HttpServerletRequest 装请求信息类
        //HttpServerletRespionse 装相应信息的类
        Cookie cookie=new Cookie("sessionId","CookieTestInfo");
        response.addCookie(cookie);
        return "添加cookies信息成功";
    }

上边,可以看到,我new了个Cookie,name是sessionId,value是CookieTestInfo; 接下来我们看看怎么取。

//非注解方式获取cookie中对应的key值

@RequestMapping(value = "/getCookies",method = RequestMethod.GET)
public  String getCookies(HttpServletRequest request){
    //HttpServletRequest 装请求信息类
    //HttpServletRespionse 装相应信息的类
 //   Cookie cookie=new Cookie("sessionId","CookieTestInfo");
    Cookie[] cookies =  request.getCookies();
    if(cookies != null){
        for(Cookie cookie : cookies){
            if(cookie.getName().equals("sessionId")){
                return cookie.getValue();
            }
        }
    }

   return  null;
}

上边注意了,看到那个循环没,这是非常有必要的! 因为这不是通过注解方式去获取Cookie中对应的key值(注解方式下边有介绍),所以得用这种方式去获取(看到里面的if没,就是通过Cookie的name:sessionId去拿值),如果执行成功,会显示在网页上的,因为这个是个@RestController。

 

//注解方式获取cookie中对应的key值

@RequestMapping("/testCookieValue")
public String testCookieValue(@CookieValue("sessionId") String sessionId ) {
   //前提是已经创建了或者已经存在cookie了,那么下面这个就直接把对应的key值拿出来了。
   System.out.println("testCookieValue,sessionId="+sessionId);
  
   
    return "SUCCESS";
}

上边的代码,你可以看到实际上通过注解方式去获取Cookie信息的话,是非常!简单!的!,直接@一下,然后String sessionIValue=sessionId; 就拿出来了!


好了,Cookie的简单使用,就这样子吧。

  • 29
    点赞
  • 76
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 11
    评论
### 回答1: Spring Boot设置Cookie的步骤如下: 1. 在Controller中使用@CookieValue注解获取Cookie的值。 2. 在Controller中使用@CookieValue注解设置Cookie的值。 3. 在Controller中使用HttpServletResponse对象设置Cookie的值。 4. 在Controller中使用HttpServletRequest对象获取Cookie的值。 5. 在Controller中使用HttpServletRequest对象删除Cookie的值。 6. 在application.properties或application.yml文件中设置Cookie的属性。 7. 在WebSecurityConfigurerAdapter中设置Cookie的属性。 以上是Spring Boot设置Cookie的基本步骤,具体实现可以参考Spring Boot官方文档或相关教程。 ### 回答2: Spring Boot 在处理 Web 应用程序时,我们经常需要与浏览器交互,比如保存用户的登录状态、浏览历史等等,这些数据都需要通过 Cookie 来进行存储和传递。因此,设置 Cookie 是 Web 开发中常基础的操作之一。 Spring Boot 中设置 Cookie常简单的,首先我们需要通过 HttpServletResponse 类的 addCookie() 方法来创建一个 Cookie 对象,并将其添加至响应中,示例代码如下: ```java @GetMapping(value = "/set-cookie") public String setCookie(HttpServletResponse response) { Cookie cookie = new Cookie("username", "springboot"); cookie.setHttpOnly(true); response.addCookie(cookie); return "setCookie success"; } ``` 在上述示例中,我们创建了一个名为 username,值为 springbootCookie 对象,然后设置了 HttpOnly 属性,并通过 HttpServletResponse 的 addCookie() 方法将其添加至响应中。HttpOnly 属性设置为 true 时,浏览器无法通过 JavaScript 的方式访问该 Cookie,这样可以有效地防止 XSS 攻击。 除了设置值之外,Cookie 还可以设置有效期、作用域等属性,示例代码如下: ```java @GetMapping(value = "/set-cookie") public String setCookie(HttpServletResponse response) { Cookie cookie = new Cookie("username", "springboot"); cookie.setMaxAge(60 * 60 * 24 * 7); // 生命周期为一周 cookie.setPath("/"); // 设置作用域为根目录 cookie.setHttpOnly(true); response.addCookie(cookie); return "setCookie success"; } ``` 在上述示例中,我们设置了 Cookie 的生命周期为一周,作用域为根目录,并将 HttpOnly 属性设置为 true。 总结来说,Spring Boot 中设置 Cookie 简单方便,只需要通过 HttpServletResponse 的 addCookie() 方法创建一个 Cookie 对象,并添加至响应中即可。同时,为了加强安全性,我们还可以设置 HttpOnly 等更多属性。 ### 回答3: Spring Boot是一个流行的Java框架,用于构建Web应用程序。在Web开发中,Cookie是一种存储在客户端浏览器中的小型文本文件。与Session相比,Cookie更加灵活,因为它可以存储在浏览器中并在多个请求之间传递,从而使Web应用程序更加可靠和互动。 为了在Spring Boot应用程序中设置Cookie,您可以使用Spring MVC框架提供的Cookie API。要设置Cookie,首先需要创建一个Cookie对象,然后将其添加到响应中。以下是设置Cookie的一些步骤: 1. 创建Cookie对象:使用Cookie构造函数创建一个新的Cookie对象,并设置其名称和值。例如,以下代码创建一个名为“username”的Cookie,并将其值设置为“john”: Cookie cookie = new Cookie("username", "john"); 2. 设置Cookie属性:在创建Cookie对象后,您可以设置其属性。例如,您可以设置Cookie的路径,使其仅适用于特定的Web页面。以下代码将Cookie的路径设置为“/admin”: cookie.setPath("/admin"); 3. 将Cookie添加到响应中:最后,将Cookie对象添加到响应中,以便将其发送到客户端浏览器。使用HttpServletResponse对象的addCookie()方法添加Cookie对象。以下是将Cookie添加到响应的代码: response.addCookie(cookie); 完整的代码示例: @RequestMapping("/set-cookie") public String setCookie(HttpServletResponse response) { // Create a new cookie with name and value Cookie cookie = new Cookie("username", "john"); // Set the cookie path cookie.setPath("/admin"); // Add the cookie to the response response.addCookie(cookie); // Return a message return "Cookie has been set!"; } 在上述代码中,控制器设置了一个名为“username”的Cookie,并将其值设置为“john”。还可以设置Cookie的路径或任何其他属性,以满足特定的Web应用程序的需求。该方法返回一个字符串,表示Cookie已被设置。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 11
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小目标青年

对你有帮助的话,谢谢你的打赏。

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值