05 SpringBoot之跨域

1 跨域

刚开始不做任何配置时 , 通过VUE调用SB的接口 , 就会报错:"...has been blocked by CORS policy"

什么意思?

后端实际上已经接收到请求 , 也完成了处理 , 返回了处理后的数据 , 但被浏览器拦截了.

浏览器为什么拦截?

浏览器的同源策略 : 限制不同源之间的交互 , 以避免不同源的攻击 . 必须符合同源策略的请求 , 才能相互访问

什么是同源策略?

协议+域名+端口 , 三个都相同时才为同源.

现在知道为什么访问不了了:

由于前后端分离 , 故两端的访问端口不一样 . VUE项目默认启动在8181端口 , 而SB默认启动在8080端口 , 不符合同源策略.

CORS跨域资源共享 , 实质由许多HTTP头组成

解决办法:

  1. 在handler上增加@CrossOrigin
    但若handler太多 , 第一种方法就稍显冗余了.
  2. 统一增加一个过滤器
java 复制代码
package com.sunsplanter.utils;

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;

@Configuration
public class CorsConfig {
    @Bean
    //返回一个corsFilter过滤器
    //创建过滤器需要一个参数:对象source ,
    // source需要注册一个corsConfiguration
    //corsConfiguration需要声明规则
    public CorsFilter corsFilter(){
        CorsConfiguration corsConfiguration = new CorsConfiguration();
        //*为通配符 , 表示允许所有请求域通过
        corsConfiguration.addAllowedOrigin("*");
        //*为通配符 , 表示允许所有请求头通过
        corsConfiguration.addAllowedHeader("*");
        //*为通配符 , 表示允许所有请求方法通过
        corsConfiguration.addAllowedMethod("*");
        
        UrlBasedCorsConfigurationSource source = new UrlBasedCorsConfigurationSource();
        source.registerCorsConfiguration("/**",corsConfiguration);

        return new CorsFilter(source);
    }
}

IoC自动装配 , 无需再次调用 ,该全局规则会自动生效 .

相关推荐
哎呀呀嗯呀呀9 分钟前
class 031 位运算的骚操作
java·算法·位运算
2401_8581205313 分钟前
古典舞在线交流平台:SpringBoot设计与实现详解
java·spring boot·后端
大白飞飞20 分钟前
IDEA创建、导入、删除maven项目
java·maven·intellij-idea
赐你岁月如歌25 分钟前
如何使用ssm实现基于web的网站的设计与实现+vue
java·后端·ssm
凯子坚持 c40 分钟前
C语言复习概要(四)
c语言·开发语言
何陈陈1 小时前
【Linux】线程池
linux·服务器·开发语言·c++
清风玉骨1 小时前
Qt-QHBoxLayout布局类控件(42)
开发语言·qt
2401_857297911 小时前
秋招内推2025-招联金融
java·前端·算法·金融·求职招聘
一 乐1 小时前
考研论坛平台|考研论坛小程序系统|基于java和微信小程序的考研论坛平台小程序设计与实现(源码+数据库+文档)
java·数据库·学习·考研·微信·小程序·源码
一 乐1 小时前
租拼车平台|小区租拼车管理|基于java的小区租拼车管理信息系统小程序设计与实现(源码+数据库+文档)
java·数据库·vue.js·微信·notepad++·拼车