vue-spring boot跨域问题

因前端端口号8080,后端端口号9090,运行之后报了一堆错,下面是报错内容截图:vue-spring boot跨域问题_第1张图片

以下是解决方法:

①在我们的项目里面新建一个config的包,在包里面建一个名叫CorsConfig的类,看图

vue-spring boot跨域问题_第2张图片

②在CorsConfig.java文件里面粘贴以下代码:

package com.example.demo.config;
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 {
    // 当前跨域请求最大有效时长。这里默认1天
    private static final long MAX_AGE = 24 * 60 * 60;
    
    @Bean
    public CorsFilter corsFilter() {
        UrlBasedCorsConfigurationSource source = new UrlBasedCorsConfigurationSource();
        CorsConfiguration corsConfiguration = new CorsConfiguration();
        corsConfiguration.addAllowedOrigin("http://localhost:8080"); // 1 设置访问源地址
        corsConfiguration.addAllowedHeader("*"); // 2 设置访问源请求头
        corsConfiguration.addAllowedMethod("*"); // 3 设置访问源请求方法
        corsConfiguration.setMaxAge(MAX_AGE);
        source.registerCorsConfiguration("/**", corsConfiguration); // 4 对接口配置跨域设置
        return new CorsFilter(source);
    }
}
corsConfiguration.addAllowedOrigin("*");也可以设置为*,所有的源地址都可以访问。

重启之后即可发现把值已经传过来了
vue-spring boot跨域问题_第3张图片

 

你可能感兴趣的:(前端框架)