React + Axios跨域请求

一、跨域概念

违背同源策略请求称为跨域请求
同源策略:IP、协议、端口相同的请求

二、前后端中跨域现象

此处展示前端请求后端非同一端口情况下

  • 1.网络栏出现CORS错误
    在这里插入图片描述
  • 2.可以发现跨域请求后端返回状态码是200,源地址为前端3000端口,主机地址为后端地址8080端口
    在这里插入图片描述
  • 3.控制台页面报错找不到后端返回的Access-Control-Allow-Origin选项信息
    在这里插入图片描述

三、跨域解决方案(2种)

0、产生原因

  • 由于浏览器不允许非同源地址访问,导致服务器响应数据到浏览器时会被拦截,故访问后端返回状态码正确但前端渲染接收数据异常。
前端:3000 后端:8080 HTTP请求 浏览器拦截 前端:3000 后端:8080

1、前端解决(React框架)

前端搭建代理服务器实现

前端:3000 代理服务器:3000/api 后端:8080 HTTP请求 HTTP请求 响应返回 响应结果并交由前端渲染 前端:3000 代理服务器:3000/api 后端:8080

解决原理:

  • 利用服务器访问后端时作为客户端进行访问不受限制
  • 前端访问与自己同源的服务器时也不受限制

配置过程

http-proxy-middleware文档
Axios文档

前期工具

npm i http-proxy-middleware
npm i axios

(1)、在React项目的src文件夹下创建文件setupProxy.js并填写如下内容(src/setupProxy.js)

const {createProxyMiddleware} = require("http-proxy-middleware");
module.exports = function (app){
    app.use("/api", // 由于请求前后端此时都为3000端口,由于区分请求后端的前缀
        createProxyMiddleware({
            target:"http://127.0.0.1:8080",// 后端服务器地址
            changeOrigin: true,
            pathRewrite: {
                "^/api": ""
            } // 重写地址,将附加的api前缀去除给到后端地址
        	// 若后端请求地址为 http://127.0.0.1:8080/myprocess/
        	// 此时请求代理服务器地址应为 http://127.0.0.1:8080/api/myprocess/
        	// 此处选项就是去除api/这个前缀的
        }))
};

(2)、前端axios请求后端服务器代码(可理解为将后端的8080服务代理到前端的3000/api接口上,故代理后要请求3000/api,不是8080/api等其他端口)

	// 前端服务器地址http://127.0.0.1:3000
	// 后端服务器地址http://127.0.0.1:8080
	// 请求后端http://127.0.0.1:8080/myprocess
	axios.get('http://127.0.0.1:3000/api/myprocess')

2、后端解决(Spring-boot配置)

增加 @CrossOrigin 注解实现

@CrossOrigin // 在Controller前加入注解使得返回相应加上"Access-Control-Allow-Origin": "*"允许跨域访问
@RestController
public class processController {
    @Autowired
    MyProcessServiceImpl processService;
    @GetMapping("/myprocess")
    private List<myStruct> getData(){
        //具体实现
        return ;
    }
}

结束

文中若有多点不足还请各位评论指出(方便及时更正避免误导更多人),使此文发挥实际作用,如在配置过程中根据此方法配置后仍无法解决可以私信或评论留言,我会第一时间查看并回复!!!

Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐