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

相关推荐
rongDang18 小时前
浏览器模拟发送POST请求
前端·javascript
清汤饺子18 小时前
OpenSpec:让 AI 编程从"开盲盒"到"先签字再干活"
前端·javascript·后端
用户693717500138418 小时前
太钻 Android 了,在电鸭刷私活把我自己刷清醒了
android·前端·github
wuhen_n18 小时前
ReAct模式理论:让AI学会“思考-行动-观察”
前端·javascript·ai编程
han_18 小时前
JavaScript设计模式(七):迭代器模式实现与应用
前端·javascript·设计模式
SPC的存折18 小时前
4、Ansible之Playbook变量应用
linux·前端·chrome·ansible
吴佳浩 Alben18 小时前
Vibe Coding 时代:Vue 消失了还是 React 太强?
前端·vue.js·人工智能·react.js·语言模型·自然语言处理
wuhen_n18 小时前
错误处理与容错机制:让AI学会“从失败中学习”
前端·javascript·ai编程
Mintopia18 小时前
别再迷信“最佳实践”:适合你项目的才是对的
前端·架构
console.log('npc')18 小时前
react弹窗组件
前端·javascript·react.js