吕布的僚机
2019-06-07 02:46
采纳率: 100%
浏览 1.4k

springboot前后端分离跨域403

以前创建项目springboot跨域是使用如下方式配置跨域可以成功

@Configuration
public class CorsConfig {
    private CorsConfiguration buildConfig() {
        CorsConfiguration corsConfiguration = new CorsConfiguration();
        corsConfiguration.addAllowedOrigin("http://web.xiao-e.net:80"); // 1允许任何域名使用
        corsConfiguration.addAllowedHeader("*"); // 2允许任何头
        corsConfiguration.addAllowedMethod("*"); // 3允许任何方法(post、get等)
        return corsConfiguration;
    }

    @Bean
    public CorsFilter corsFilter() {
        UrlBasedCorsConfigurationSource source = new UrlBasedCorsConfigurationSource();
        source.registerCorsConfiguration("/**", buildConfig()); // 4
        return new CorsFilter(source);
    }

}

但是这次新建的项目同样使用上述方式配置跨域,却出现403错误
图片说明

奇怪的是如果在springboot中不配置任何跨域设置,则可以正常请求。

以下是前端配置代码和后端controller代码

proxyTable: {
      '/api': {
        target: 'http://api.xiao-e.net:8080',
        changeOrigin: true,
        pathRewrite: {
          '^/api': ''
        }
      }
    },
@RestController
@RequestMapping("user")
public class UserController {

    @Autowired
    UserService userService;

    @PostMapping("register")
    public User register(@RequestBody User user){
        return userService.addUser(user);
    }

}

api.xiao-e.net和web.xiao-e.net都是解析的127.0.0.1,为了测试跨域使用的

  • 写回答
  • 关注问题
  • 收藏
  • 邀请回答

1条回答 默认 最新

  • 懵懵的小哥 2019-06-07 12:56
    已采纳

    你的SpringBoot跨域设置图片说明
    你的前端跨域设置:图片说明
    前者端口设置为:80;后者端口设置为:8080,明显不属于同域,尝试统一端口设置试试!
    再有:前端跨域只需在前端配置即可

    已采纳该答案
    打赏 评论

相关推荐 更多相似问题