首页 > Web开发 > 详细

spingsecurity 前后端分离跨域,ajax无用户信息

时间:2019-11-19 18:40:12      阅读:138      评论:0      收藏:0      [点我收藏+]

 

1、自测时用的postman没有任何问题

 

2、和前端对接时发现登录不上,ajax Error

出错:{"readyState":0,"responseText":"","status":0,"statusText":"error"}

 

3.1、spingsecurity 配置允许跨域,.requestMatchers(CorsUtils::isPreFlightRequest).permitAll()会存在用户变成匿名用户的问题

技术分享图片

 

3.2 cors 配置类

@Configuration
public class CorsConfig {
private CorsConfiguration buildConfig() {
CorsConfiguration corsConfiguration = new CorsConfiguration();
// 你需要跨域的地址 注意这里的 127.0.0.1 != localhost
// * 表示对所有的地址都可以访问
corsConfiguration.addAllowedOrigin("*");
// 跨域的请求头
corsConfiguration.addAllowedHeader("*"); // 2
// 跨域的请求方法
corsConfiguration.addAllowedMethod("*"); // 3
//加上了这一句,大致意思是可以携带 cookie
//最终的结果是可以 在跨域请求的时候获取同一个 session
corsConfiguration.setAllowCredentials(true);
return corsConfiguration;
}
@Bean
public CorsFilter corsFilter() {
UrlBasedCorsConfigurationSource source = new UrlBasedCorsConfigurationSource();
//配置 可以访问的地址
source.registerCorsConfiguration("/**", buildConfig()); // 4
return new CorsFilter(source);
}

4.进行如上配置后发现还是匿名用户,因ajax没有带上cookie,所有ajax带上认证
技术分享图片

 

 

 

 

spingsecurity 前后端分离跨域,ajax无用户信息

原文:https://www.cnblogs.com/astrand/p/11891083.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!