首页 > 其他分享 >cookie一致性

cookie一致性

时间:2024-03-23 15:11:29浏览次数:28  
标签:web springframework cookie org 一致性 import servlet

非跨域cookie一致性解决

请求拦截器
import javax.servlet.http.Cookie;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttppServletResponse;
import org.springframework.web.servlet.HandlerInterceptor;
@Component
public class CustomInterceptor implements handlerInterceptor {
  @Overrde
  publlic boolean preHandle(HttpServletRequest reqest,HttppServletResponse response,Object handler) throws Exception {
    //从请求中获取cookie
    Cookie[] cookies = request.getCookies();          
    //将cookie放入响应中          
    Cookie sessionCookie = Arrays.stream(cookies).filter(e -> e.getName().equals("SIID").findAny().orElse(null);
    if (sessionCookie == null) {
         sessiiionCookie = new Cookie("SID",request.getSession().getId();
         response.addCookie(sessiionCookie);                  
      }    
    return true;  
  }    
}

配置完拦截器,在配置中获取拦

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.cors.CorsConfiguration;
import org.springframework.web.cors.UrlBasedCorsConfigurationSource;
import org.springframework.web.filter.CorsFilter;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;

@Configuration
public class GlobalCorsConfig implements WebMvcConfigurer {
   @Autowired
   private CustomInterceptor interceptor;  
    
   @Bean
   public CorsFilter corsFilter() {
     //1. 创建CorsConfiguration对象
        CorsConfiguration corsConfiguration = new CorsConfiguration();
        corsConfiguration.addAllowedOrigin("*");//设置允许那些域来访问,*是通配符,允许所有域(如果还不行,将*改为http:xx:8080)
        corsConfiguration.addAllowedHeader("*");//请求头字段
        corsConfiguration.addAllowedMethod("*");//请求方式(GET,POST,DELETE,PUT)
        //设置source
        UrlBasedCorsConfigurationSource source = new UrlBasedCorsConfigurationSource();
        source.registerCorsConfiguration("/**", corsConfiguration);//1.映射路径 2.传入CorsConfiguration对象
        return new CorsFilter(source);
   }  

    @Override
    public void addInterceptors(InterceptorRegisty registry) {
        // 拦截所有请求          
        registry.addInterceptor(interceptor).addPathPatterns("/**");
    }
}

  

vue全局配置cookie在main.js中

import axios from 'axios'

axios.defaults.withCredentials = true

  

标签:web,springframework,cookie,org,一致性,import,servlet
From: https://www.cnblogs.com/qtfwax/p/18086045

相关文章

  • Http-Only Cookie
    Http-OnlyCookie  设置Cookie的时候,如果服务器加上了HttpOnly属性,则这个Cookie无法被JavaScript读取(即document.cookie不会返回这个Cookie的值),只用于向服务器发送。Set-Cookie:key=value;HttpOnly上面的这个Cookie将无法用JavaScript获取。进行AJAX操作时,XMLHtt......
  • Koa项目总结五:Koa项目中cookie和session的配置和使用
    Koa项目总结五:Koa项目中cookie和session的配置和使用joyitsai关注IP属地:山东0.282019.05.2623:52:45字数1,326阅读2,4751.Cookie介绍:Cookie是保存在浏览器中的数据,可以让我们在同一个浏览器访问同一个域名时共享cookie数据。1.1使用cookie,可实现的几个常用场景:......
  • SpringBoot整合Redis:Redis优化解决数据一致性问题
    ......
  • MYSQL 同步到ES 如何设计架构保持一致性
    简单使用某个组件很容易,但是一旦要搬到生产上就要考虑各种各样的异常,保证你方案的可靠性,可恢复性就是我们需要思考的问题。今天来聊聊我们部门在MYSQL同步到ES的方案设计。在面对复杂条件查询时,MYSQL往往显得力不从心,一般公司的做法会通过将mysql中的数据同步到ES,之后的查询......
  • POSIX标准及其一致性/功能/压力测试
    1POSIX标准POSIX:PortableOperatingSystemInterfaceofUnix.,可移植操作系统接口。X表示其是对UnixAPI的传承。POSIX标准由IEEE(电气和电子工程师协会)发布,定义了操作系统应该为应用程序提供的接口标准,是IEEE为要在各种UNIX操作系统上运行软件而定义的一系列API标准的总称。......
  • 为什么延迟删除可以保证MYSQL 与redis的一致性?
    看过很多保持MYSQL与redis保持一致性的文章都提到了延迟删除,其实脱离任何业务场景的设计都是不切实际的,所以我会本着一个通用的读写场景去分析为什么延迟删除大概率可以保证MYSQL与redis的最终一致。通常的读写场景通常在使用redis作为读写缓存时,我们采用的是cacheasidepatte......
  • Redis作为缓存,MySQL数据库如何与Redis保持一致性(双写一致性)?
    Redis作为缓存,MySQL数据库如何与Redis保持一致性(双写一致性)?双写一致性:​ 修改了数据库中的数据的同时,也要更新缓存的数据,保证数据库和缓存中的数据保持一致。请求数据的执行流程:​ 请求去访问Redis,如果Redis缓存中有数据则返回数据,如果Redis缓存中没有数据则去查数据库,数......
  • 会话技术(1)Cookie
    目录1、会话是什么2、会话跟踪是什么3、HTTP协议不提供会话跟踪4、会话跟踪的实现方式5、客户端会话跟踪技术Cookie1)怎样使用2)原理1、会话是什么用户打开浏览器,访问web服务器的资源,会话建立,直到有一方断开连接,会话结束。在一次会话中可以包含多次请求和响应:从浏览......
  • 实战5-某政府采购网cookies反爬(进入前检查浏览器)
    目标网站aHR0cDovL3d3dy55bmdwLmNvbS8=1.呈现状态2.分析网站先复制请求链接的curl看看打印出的结果打印出的结果不正常,来看看请求头,里面有一个'$Cookie',转场到请求连接的cookies中看看,xincaigou这个值大概就是我们想要的往上看其他请求,找xincaigou从哪冒出来,在第二个链......
  • 高并发下如何保证数据的一致性和可靠性
    在高并发环境中,确保数据的一致性和可靠性是非常重要的。以下是一些常见的方法和策略:事务管理:使用数据库事务来确保关键操作的原子性、一致性、隔离性和持久性。通过合理的事务设计和管理,对于涉及到多个数据操作的场景,可以保证数据的一致性。数据库锁机制:使用数据库提供的锁机......