Java后端解决跨域问题

当一个请求url的协议、域名、端口三者之间任意一个与当前页面url不同即为跨域。

比如我的前端地址为:
http://localhost:8080/foodie-shop/

后端为:
http://localhost:8088

用的都是http协议,都是在本地所以都是localhost,
但是端口号不一样,所以造成了跨域问题。

我用的Java语言,并且是后端程序员,所以创建一个CorsConfig类来解决跨域问题。
【CORS是一个W3C标准,全称是"跨域资源共享"(Cross-origin resource sharing)】

CorsConfig类:在后端

package com.imooc.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 {

public CorsConfig() {
}

@Bean
public CorsFilter corsFilter() {
    // 1. 添加cors配置信息
    CorsConfiguration config = new CorsConfiguration();
    //允许前端访问的路径
    config.addAllowedOrigin("http://localhost:8080");
    config.addAllowedOrigin("http://shop.z.mukewang.com:8080");
    config.addAllowedOrigin("http://center.z.mukewang.com:8080");
    config.addAllowedOrigin("http://shop.z.mukewang.com");
    config.addAllowedOrigin("http://center.z.mukewang.com");
    config.addAllowedOrigin("*");

    // 设置是否发送cookie信息
    config.setAllowCredentials(true);

    // 设置允许请求的方式:Get/POST/...
    config.addAllowedMethod("*");

    // 设置允许的header
    config.addAllowedHeader("*");

    // 2. 为url添加映射路径
    UrlBasedCorsConfigurationSource corsSource = new UrlBasedCorsConfigurationSource();
    corsSource.registerCorsConfiguration("/**", config);

    // 3. 返回重新定义好的corsSource
    return new CorsFilter(corsSource);
}

}

别人的解决方案:
https://blog.csdn.net/qq_38128179/article/details/84956552

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值