Bootstrap

【前端+后端解决跨域问题】Access to XMLHttpRequest at ’http:x‘ from origin’http:x‘has been blocked by CORS

       学习前端的同学想必都遇到过跨域问题,那么跨域问题究竟该如何解决呢,这里提供了前端和后端不同的解决方法,供大家参考。


 目录

一. 后端解决方法

方法1:在controller文件中加上@CrossOrigin

方法2:在config配置文件夹中加上webconfig配置文件

二. 前端解决方法

方法1:在vue.config中添加proxy代理

方法2:为仍然解决不了的具体请求单独配置url接口


最近在做一个前后端分离的项目,由自己编写前端和后端代码。后端配置好之后,在前端用axios进行调用时,遇到了跨域问题。

61473c17dfef4b65b6f95fa563fe1545.png

       跨域问题是由于请求使用的ip地址或者端口,与网络接口对应的ip地址或者端口不一致而产生的。例如前端使用的url是【http://localhost:8080/users】来请求接口,这里的端口为8080,而后端默认的端口为80,因此后端的url是【http://localhost:80/users(或http://localhost/users)】,这里就出现了端口不一致导致的跨域问题。

       还有一种情况是ip地址不一致的情况导致跨域问题,例如前端使用url为【http://127.0.0.1:8080/users】,而后端的接口为【http://127.0.0.2:8080/users】,这是ip地址不一致的情况。


一. 后端解决方法

(注意我配置接口用的是springMVC,因此只针对用springMVC的同学解决跨域问题)

方法1:在controller文件中加上@CrossOrigin

①在类的上面添加@CrossOrigin,解决全局跨域问题

2731661ba67848519170aaf9fc99e8f9.png

②在对应的方法名上添加,解决单个接口的跨域问题

(可以在(origins)中写上前端的url接口允许特定端口的跨域请求)

6c072f6127a244e099a35c8d9d6d0d88.png


方法2:在config配置文件夹中加上webconfig配置文件

这样可以在全局解决跨域问题,其中的【/users/】换上你自己要请求的路径

7c201b89b0a64be7a71353ddf692ecb8.png

import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.CorsRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;

@Configuration
public class WebConfig implements WebMvcConfigurer {

    @Override
    public void addCorsMappings(CorsRegistry registry) {
        // 允许所有域名访问 /users/** 路径
        registry.addMapping("/users/**")
                .allowedOrigins("http://localhost:8080")  // 允许来自 http://localhost:8080 的请求
                .allowedMethods("GET", "POST", "PUT", "DELETE")  // 允许的请求方法
                .allowedHeaders("*")  // 允许的请求头
                .allowCredentials(true);  // 是否允许携带认证信息(如 Cookies)
    }
}

二. 前端解决方法

方法1:在vue.config中添加proxy代理

①【/users】换成你自己要请求的接口,我要请求的是【http://localhost/users/xxx】

②【target: "http://localhost:80"】也是换成你自己要请求的接口,【80】是你自己后端的端口号。为什么和上面的不一样呢,因为后端配置的端口默认是80,写不写都这个80都是请求到这个端口。也就是说【http://localhost:80】等于【http://localhost】。

998468f4968d450abd81244d74fab19c.png


       这里插一句,经过以上前端后端的一大堆操作之后(其实只用后端的方法1就可以了),你会发现发送get、put、delete请求已经没问题了,就算前端是8080的端口,也会自动被代理成80,成功实现不同端口的跨域请求。

     但是却发送不了post请求,依然显示跨域问题。通过f12查询网络请求发现,你发出的8080端口请求没有被代理变成80。这是为什么呢?

     我询问gpt,说是因为post请求要提交数据对象,和其他方法不太一样(这里其实我没懂,put和delete请求不是也要传数据对象吗,如果有大佬懂的话希望可以帮我解释一下),因此要在axios对应的方法上直接硬配置后端的端口。

   (该图中我已经解决该问题了,只是告诉你怎么看你真正发送的url是什么)

5020381a7c744673b5e6d92db0f39836.png


方法2:为仍然解决不了的具体请求单独配置url接口

我的post请求依然无法解决跨域问题,因此我直接在post请求的url这里硬改成了后端的接口。

2b06410d9d4248cf97322f1693075a4f.png

这是正常的其他url,默认为前端的8080接口,会被代理自动转成后端的80接口。 

385a23f63bdb4da3a1967c94e41dc845.png


到这里所有的方法都介绍完毕了,可以正常访问接口了,希望以上方法可以帮到大家。

74ad2715d71f4cfca6885082b35583b7.png

 

 

;