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*地址**

相关推荐
旧雨散尘4 分钟前
【react】react初学6-第一个react应用-待办事项
前端·react.js·前端框架
Tzarevich7 分钟前
现代JavaScript字符串处理:从基础语法到模板字符串的深度演进与技术实践
javascript
岁月向前15 分钟前
iOS基础问题整理
前端
陈随易17 分钟前
改变世界的编程语言MoonBit:配置系统介绍(下)
前端·后端·程序员
jump68019 分钟前
【react】 useReducer 集中式管理组件的状态
前端
许泽宇的技术分享25 分钟前
把 CLI 搬上 Web:在内网打造“可二开”的 AI IDE,为什么这条路更现实?
前端·ide·人工智能
jump68040 分钟前
【react】useState是什么,怎么用
前端
进击的夸父1 小时前
前端合并的表格排序功能
前端
低保和光头哪个先来1 小时前
如何实现弹窗的 双击关闭 & 拖动 & 图层优先级
前端·javascript·css·vue.js
必然秃头1 小时前
前端面试题总结
前端