首页IT科技proxy代理跨域(Vite代理解决跨域问题)

proxy代理跨域(Vite代理解决跨域问题)

时间2025-05-04 04:41:09分类IT科技浏览3469
导读:Vite代理解决跨域问题 我们在编写前端项目的时候,经常会遇到跨域的问题,当我们访问后端 API 的 URL 路径时,只要域名、端口或访问协议(如 HTTP 和 HTTPS)有一项不同,就会被浏览器认定为跨域。另外我们也会经常重复编写后端的域名,例如 https://example.com...

Vite代理解决跨域问题

我们在编写前端项目的时候            ,经常会遇到跨域的问题                  ,当我们访问后端 API 的 URL 路径时      ,只要域名            、端口或访问协议(如 HTTP 和 HTTPS)有一项不同            ,就会被浏览器认定为跨域            。另外我们也会经常重复编写后端的域名                  ,例如 https://example.com/api/some_end_point      ,https://example.com/api/other_end_point      ,针对这两种情况                  ,可以直接用同一个配置来解决            ,即代理配置                  。

不管是 Vite 还是 Webpack      ,这些打包工具都支持设置前端代理                  ,它们能够把对某一段 URL 的访问直接转换成另一个真实的后端 API 地址            ,这样前后端就视为使用了相同的域名                  、协议和端口,就避免了跨域的问题                  ,还能避免繁琐的反复编写域名      。

1.Vite Proxy

我们这里以 Vite 的配置为例                  ,来看一下如何给 API 请求设置代理            。在 Vite 编写的项目里边,有一个 vite.config.js配置文件            ,里边是关于 Vite 的配置项                  ,可以在里边配置代理                  。假如我们前端项目路径为 http://localhost:3000      ,需要代理所有以 /api 开头的 API 请求            ,把它转发到 http://localhost:3001                  ,并且后端的 API 路径中不带 /api前缀      ,需要自动去掉 /api前缀      ,如下图所示:

下面是端口从5173代理到8080

import { defineConfig } from vite import vue from @vitejs/plugin-vue // https://vitejs.dev/config/ export default defineConfig({ plugins: [vue()], server: { proxy: { /api: { target: http://127.0.0.1:8080, //目标url changeOrigin: true, //支持跨域 rewrite: (path) => path.replace(/^\/api/, ""), //重写路径,替换/api } } } })

注意我先配置了axios的baseurl

// 请求 const service = axios.create({ baseURL: /api, timeout: 10000 })

也就是说 我请求request.get("/all")                   ,会解析成http://127.0.0.1:5173/api/all      。

这里我请求http://127.0.0.1:5173/api/all 这是前端的请求      。

http://127.0.0.1:8080/all 这里对应后端的接口                  。

前端

后端

2.参考文章

传送门

创心域SEO版权声明:以上内容作者已申请原创保护,未经允许不得转载,侵权必究!授权事宜、对本内容有异议或投诉,敬请联系网站管理员,我们将尽快回复您,谢谢合作!

展开全文READ MORE
servlet与html交互(一文弄懂Vue与Servlet的交互:让你的大学课设变得容易起来) 网站快速优化排(自己怎么优化网站靠前)