码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • React跨域请求,http-proxy-middleware代理服务,Axios实现前端请求


    React + Axios跨域请求

    React跨域

    • React + Axios跨域请求
    • 一、跨域概念
    • 二、前后端中跨域现象
    • 三、跨域解决方案(2种)
      • 0、产生原因
      • 1、前端解决(React框架)
        • 解决原理:
        • 配置过程
      • 2、后端解决(Spring-boot配置)
    • 结束

    一、跨域概念

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

    二、前后端中跨域现象

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

    • 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
    • 2

    (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/这个前缀的
            }))
    };
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14

    (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')
    
    • 1
    • 2
    • 3
    • 4

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

    增加 @CrossOrigin 注解实现

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

    结束

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

  • 相关阅读:
    ROS中Rviz实时路径可视化的高效性能优化技巧
    一文带你了解TikTok广告账户以及如何进行TikTok广告投放
    Prompts(二)
    安防监控/视频汇聚平台EasyCVR云端录像不展示该是什么原因?该如何解决?
    Jest 学习笔记
    【目标检测】目标检测的评价指标(七个)
    springboot的@ConditionalOnBean注解
    echarts柱状图TOP排名
    Vue中的事件总线(EventBus)是什么?它有什么优点和缺点?
    2023年天津理工大学中环信息学院专升本专业课报名考试须知
  • 原文地址:https://blog.csdn.net/qq_24269643/article/details/128195729
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号