解决has been blocked by CORS policy: No ‘Access-Control-Allow-Origin’报错跨域问题

1 问题描述

vue+springboot,将图片放在服务器端,利用html2canvas绘制DOM中的内容,出现跨域问题

试过了添加:

:src="shareUrlContent.getUrlImageUrl+'?'+new Date().getTime()"
crossorigin="anonymous"

不管用;

2 解决办法

往后端添加'Access-Control-Allow-Origin' '*';

添加注意事项:

先看报错提示

Access to image at 'http://****:9022/images/551-1-(2023-7-28).jpg?1692015834355' from origin 'http://****:9016' has been blocked by CORS policy: No 'Access-Control-Allow-Origin' header is present on the requested resource.

 我的前后端部署到一个服务器上,但是端口不一样,前端9016,后端9018,图片访问的端口也是独立的,为9022(我这个当时有点问题,所以图片没用和后端一样的端口);

从报错消息看,大致就是跨域,需要添加Access-Control-Allow-Origin;前端端口添加Access-Control-Allow-Origin实在nginx.conf中,而后端端口添加Access-Control-Allow-Origin是在代码中配置代码中加;

而这个项目是图片访问不到,而图片的端口在9022;所以需要对9022这个端口的接口代码中添加,以springboot为例,添加以下全局配置文件:

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 MyCorsConfig {
    @Bean
    public CorsFilter corsFilter(){
        //1.添加CORS配置信息
        CorsConfiguration config = new CorsConfiguration();
        //1) 允许的域,不要写*,否则cookie就无法使用了
        config.addAllowedOrigin("http://localhost:9016"); //这里填写请求的前端服务器
        //2) 是否发送Cookie信息
        config.setAllowCredentials(true);
        //3) 允许的请求方式
        config.addAllowedMethod("OPTIONS");
        config.addAllowedMethod("HEAD");
        config.addAllowedMethod("GET");
        config.addAllowedMethod("PUT");
        config.addAllowedMethod("POST");
        config.addAllowedMethod("DELETE");
        config.addAllowedMethod("PATCH");
        // 4)允许的头信息
        config.addAllowedHeader("*");

        //2.添加映射路径,拦截一切请求
        UrlBasedCorsConfigurationSource configSource = new UrlBasedCorsConfigurationSource();
        configSource.registerCorsConfiguration("/**", config);

        //3.返回新的CorsFilter.
        return new CorsFilter(configSource);
    }
}

需要注意的是,前端端口的地址一定要和vue端口的地址对应。

然后重启就可运行了

  • 7
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值