前后端项目解决跨域问题

跨域请求

  • 前端
  • 后端

前端

前端框架使用Vue

  • 在config.js中配置跨域请求
module.exports = {
  //相当于webpack-dev-server,  对本地服务器进行配置
  devSever: {
    proxy:  {
      "/api" : {
        target: " http://localhost:8081 ",   //需要跨域的目标url ,我这里是自己本地起的一个服务端口
        changeOrigin: true,           // 将基于名称的虚拟托管网站的选项,如果不配置,请求会报404
        ws:  true,
        pathRewrite: {
          " ^/api " :  ""          //若请求的路径在目标url下但不在/api 下,则将其转换成空
        }
      }
    }
  }
}

后端

后端框架使用springboot

  • 新建配置类CorsConfig
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("*"); // 1 设置访问源地址
        corsConfiguration.addAllowedHeader("*"); // 2 设置访问源请求头
        corsConfiguration.addAllowedMethod("*"); // 3 设置访问源请求方法
        corsConfiguration.setMaxAge(MAX_AGE);
        source.registerCorsConfiguration("/**", corsConfiguration); // 4 对接口配置跨域设置
        return new CorsFilter(source);
    }
}

你可能感兴趣的:(实战项目,vue.js,前端,spring,boot)