当前位置: 首页 > news >正文

react中使用nextjs框架,前端调后端接口跨域解决方式

前端在项目目录中next.config.js文件中添加以下代码

async rewrites() {return [{source: "/api/:path*",destination: `${process.env.NEXT_PUBLIC_API_DOMAIN}/api/:path*`,basePath: false}]}

截图:

  • source: "/api/:path*": 定义了一个 URL 模式,匹配所有以 /api/ 开头的请求,并将 :path* 作为一个通配符来匹配其后的路径部分。

  • destination: "${process.env.NEXT_PUBLIC_API_DOMAIN}/api/:path*": 将匹配的请求代理到 NEXT_PUBLIC_API_DOMAIN 所定义的后端 API。process.env.NEXT_PUBLIC_API_DOMAIN 是一个环境变量,通常在 .env 文件中定义。例如,如果 NEXT_PUBLIC_API_DOMAIN (后端接口ip:端口)的值是 https://api.example.com,那么请求 http://localhost:3000/api/users 就会被代理到 https://api.example.com/api/users

  • basePath: false: 禁用 basePath,确保重写规则不受 basePath 配置的影响。

注意:不要配置axios的baseURL,让其默认是localhost:xxx地址请求接口,它会转发到${process.env.NEXT_PUBLIC_API_DOMAIN}/api/:path*地址


http://www.mrgr.cn/news/1123.html

相关文章:

  • 集合及数据结构第二节————算法、时间复杂度和空间复杂度
  • MPP之Clickhouse
  • 如何在Linux上使用TensorFlow进行机器学习
  • 建造者模式 和 外观模式
  • C知识扫盲------文件的基本操作
  • RCE---eval长度限制绕过技巧
  • 源头分析: 网络安全的分布式方法
  • 基于大模型 Prompt + LangChain 架构的 AI 翻译系统全流程解析
  • AI学习记录 - Word2Vec 超详细解析
  • c++进阶——继承的定义,复杂的菱形继承及菱形虚拟继承
  • JZ51 数组中的逆序对
  • HarmonyOS 开发
  • 设计模式 建造者模式
  • C++ //练习 18.6 已知下面的异常类型和catch语句,书写一个throw表达式使其创建的异常对象能被这些catch语句捕获:
  • 非关系型数据库MongoDB(文档型数据库)介绍与使用实例
  • 安装Pentaho Data Integration并启动
  • C++入门——08list
  • Flutter-->使用dart编写蒲公英上传脚本
  • 七大排序算法
  • 基于飞腾平台的Hadoop的安装配置