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

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

javascript 复制代码
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*地址**

相关推荐
OpenTiny社区几秒前
WebSkill —— 运行在浏览器的 Agent 技能
前端·开源·ai编程
Amos_Web11 分钟前
Solana 智能合约编译问题排查与修复总结
前端·rust·区块链
爱折腾的军哥18 分钟前
首发 | OpenTaiji WFGY 防幻觉系统:让 AI Agent 不再"胡说八道"
javascript
颜酱24 分钟前
从零实现「拍照记单词」小应用(可复刻版)
前端·javascript·人工智能
大猫会长28 分钟前
AudioContext给音频提高音量
前端·javascript·音视频
kerli34 分钟前
基于 kmp/cmp 的跨平台图片加载方案 - 适配 Android View/Compose/ios
android·前端·ios
RONIN1 小时前
vue组件、组件生命周期、组件分离模块化
前端·vue.js
小强19881 小时前
HTML5语义化标签:从`div`到`article`与`section`的进化之路
前端
RONIN1 小时前
vue开发环境与基础语法、计算属性、侦听属性
前端·vue.js
WayneYang1 小时前
JavaScript ES6+ (ES2015~ES2024) 全特性整理
前端·javascript