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

南通网站建设团队合肥百度关键词推广

南通网站建设团队,合肥百度关键词推广,湖南人文科技学院全国排名,北京模板网站建设引言 本文介绍如何在开发环境下解决 Vite 前端(端口 3000)和后端(端口 80)之间的跨域问题: 在开发环境中,前端使用的 Vite 端口与后端端口不一致,会产生跨域错误提示: Access to X…

引言

本文介绍如何在开发环境下解决 Vite 前端(端口 3000)和后端(端口 80)之间的跨域问题:

在开发环境中,前端使用的 Vite 端口与后端端口不一致,会产生跨域错误提示:
Access to XMLHttpRequest at 'http://localhost/api/some-endpoint' from origin 'http://localhost:3000' has been blocked by CORS policy: Response to preflight request doesn't pass access control check: No 'Access-Control-Allow-Origin' header is present on the requested resource.

解决方案

通过在 Vite 配置文件vite.config.tsvite.config.js中设置代理,将前端请求转发到后端,从而绕过跨域限制。

在这里插入图片描述

操作步骤:

  1. 打开 vite.config.tsvite.config.js,添加 server.proxy 属性。

  2. 配置代码示例:

    import { defineConfig } from 'vite'
    import vue from '@vitejs/plugin-vue'export default defineConfig({plugins: [vue()],server: {proxy: {'/api': {target: 'http://localhost:80', // 后端地址changeOrigin: true,rewrite: (path) => path.replace(/^\/api/, '') // 移除路径中的 /api 前缀}}}
    })
    

在此配置中,所有发往 /api 的请求都会被代理到 http://localhost:80,并移除 /api 前缀(具体根据你的后端接口路径调整)。

  1. 修改前端请求的 URL:

    将之前的请求:

    axios.get('http://localhost/api/some-endpoint');
    

    改为:

    axios.get('/api/some-endpoint');
    

Vite 会自动将 /api/some-endpoint 请求代理到 http://localhost:80/some-endpoint,实现与后端的跨域通信。

请求流程

在此配置下,axios.get('/api/some-endpoint') 实际会被代理到后端的 http://localhost:80/some-endpoint

  1. 请求路径axios.get('/api/some-endpoint') 先发送到开发服务器(例如 localhost:3000)。
  2. 代理配置:Vite 检测到请求路径包含 /api,会将它代理到目标地址 http://localhost:80
  3. 路径重写rewrite 函数移除 /api 前缀。
  4. 最终地址:请求被代理转发到 http://localhost:80/some-endpoint

配置的意义

尽管直接请求 http://localhost:80/api/some-endpoint 是正确的后端地址,但 Vite 代理配置能避免跨域问题,简化代码,并更灵活地适配不同环境。代理配置的主要作用是:

  1. 解决同源策略限制:即使端口相同,浏览器也会限制跨域请求,而代理让前端和后端之间的请求看起来是同源的。
  2. 路径简化:设置代理后,代码只需写 /api 路径,方便维护。
  3. 更好的环境切换:代理配置可轻松适配开发、测试、生产等不同环境。

配置效果总结:

  • 避免跨域限制:请求通过代理后,看起来是发往开发服务器的,绕过跨域限制。
  • 代码简洁:代理后代码路径更简洁,便于管理。
  • 环境适配:代理配置使切换环境更方便,只需更改 target 地址。

长路径代理的配置示例

如果你的请求路径较长,并且希望代理后的地址保留原始路径结构,例如 http://localhost:80/csdn/test/bbq/api/some-endpoint,可以使用如下配置来实现(注意,80 是默认端口,可以省略不写):

// vite.config.ts
import { defineConfig } from 'vite';export default defineConfig({server: {proxy: {'/csdn': {// 后端服务器地址target: 'http://localhost:80/csdn/',changeOrigin: true,rewrite: path => path.replace(/^\/csdn/, '')}}}
});

在具体请求中:

// 示例请求代码
const postUrl = 'http://localhost:3000/csdn/test/bbq/api/some-endpoint';

说明

这里的思路是通过本地开发服务器(前端所在服务器)反向代理到后端所在服务器。你发出的请求指向 localhost:3000,Vite 代理会将其转发至 localhost:80 的相应路径。

因此,尽管请求地址使用了 3000 端口,但代理机制会帮你将其转换为原始的后端路径结构,从而实现数据交流。

问题

目前实际开发的时候我遇到一个问题就是后端可能无法获得正确的ip地址,当然啦,这是小问题。如果你还发现什么弊端可以留言给大家分享。

http://www.dt0577.cn/news/19783.html

相关文章:

  • 南京网络推广建站查网站域名
  • 备案用的网站建设方案书怎么样推广最有效最快速
  • 网站建设思维导图模版火狐搜索引擎
  • 网站推广被封域名如何做跳转河南网站推广那家好
  • 网站建设会计帐务处理搜索引擎营销的主要方式有
  • 网站顶部怎么做新浪链接seo系统培训课程
  • 免费做名片儿的网站360地图下载最新版
  • 苏州网站制作哪家靠谱广州seo教程
  • 摄影网站上的照片做后期嘛搜索引擎优化英文简称为
  • 温州建设监理协会网站河北seo技术培训
  • 帮人做彩票网站网络营销师证
  • 学做网站能赚多少南宁网站推广大全
  • 微信商城网站怎么开发网页代码大全
  • 喷泉网站哪里做自动app优化官网
  • 冷库网站建设毕业论文全域seo
  • 海南网站建设公司网络广告有哪些形式
  • 高端企业网站建设费用百度最怕哪个投诉电话
  • 京东网站建设目标湖南最新消息今天
  • google 网站优化工具广告公司是做什么的
  • 无锡做网站优化公司做销售有什么技巧和方法
  • 重庆模板网站哪个好seo优化师就业前景
  • 澳门网站建设维护营销助手
  • 网站系统建设招标文件成都百度推广代理公司
  • wordpress适合企业网站模板优化营商环境的金句
  • 如何做互联网创业优化是什么意思?
  • 微信如何做微商城网站建设stp营销战略
  • 精品网站导航 做最好的导航5118营销大数据
  • 上海网站建设方案如何做好一个网站
  • 我做的网站在手机里滑动怎么这里卡泰安seo公司
  • 网站推广的8种方法30个免费货源网站