转行小白历险记-2023.12.19 如何解决跨域问题

讨厌突如其来的破坏计划的感觉,真的好烦

一、跨域以及如何解决跨域问题(反向代理)

跨域

  1. 同源:协议、端口、域名相同

如何解决跨域问题

  1. jsonp:<script> 不受同源策略限制
  2. 跨源域资源共享 CORS:允许 Web 应用服务器进行跨源访问控制
  3. 使不同的源变成同源

什么时是反向代理

  1. 代理:请求转发
  2. 正向代理:客户端告诉代理服务器的地址
  3. 反向代理:客户端只需要告诉需要的东西

二、介绍 vite

由两个部分组成

  1. 开发服务器:基于ES模块提供丰富的内建功能
  2. 构建指令:使用Rollup 打包代码,提供预设配置

热更新:

  1. 修改的东西会立刻反应到页面上,叫做热更新

为什么选择vite

复制代码
  #### 启动本地开发服务器的时间会很久

  1. 依赖:使用**esbuild**进行依赖预打包,esbuild 使用 Go 编写,会比javascript-based 的打包工具快 10-100 倍
  2. 源码:使用**浏览器原生es module 提供源码**,让浏览器接管打包工具的部分工作
复制代码
  #### 热更新也会很慢

  1. 使用**ESM 不需要重新编译**:一些打包工具的开发服务器在文件更改时,需要重新构建整个项目,来获取新的模块依赖关系
  2. 使用**浏览器缓存加速** :Vite 利用**HTTP头**来加速整个页面的重新加载

三、使用vite配置请求代理

使用 Vite 或 Webpack Dev Server

在开发环境中,可以在 Vite 或 Webpack Dev Server 中配置反向代理:

javascript 复制代码
// Vite 配置示例
export default {
  server: {
    proxy: {
      '/api': {
        target: 'http://backend.example.com', // 后端服务器地址
        changeOrigin: true,
        rewrite: path => path.replace(/^\/api/, '')
      }
    }
  }
}
相关推荐
阿里matlab建模师1 分钟前
【机场停机位分配】matlab实现基于遗传算法的机场停机位分配优化研究
开发语言·算法·数学建模·matlab·全国大学生数学建模竞赛
xiaoshuaishuai81 分钟前
C# Avalonia 依赖属性与WPF的区别
开发语言·c#·wpf
一碗白开水一2 分钟前
【训练技巧】bash: conda: command not found:conda 没有适配环境
开发语言·conda·bash
excel5 分钟前
从封装到继承:深入理解 TypeScript 类中的 public、private、protected、static
前端
imkaifan5 分钟前
工作流(Worker/Graph)配置对象如何解读、子图
javascript·工作流·(worker/graph)·配置对象如何解读·子图
一晌小贪欢5 分钟前
第22节:相关性分析——协方差、相关系数与热力图解读
开发语言·python·数据分析·pandas·数据可视化
向日的葵0065 分钟前
vue3路由的replace属性(四)
前端·javascript·vue.js·vue路由
杨超越luckly6 分钟前
Agent应用指南:利用GET请求获取理想汽车门店位置信息
前端·python·html·汽车·可视化
阿猫的故乡6 分钟前
Vue模板引用和组件暴露:ref拿DOM、defineExpose调方法,案例多到眼花
前端·javascript·vue.js
keykey6.7 分钟前
循环神经网络(RNN)与序列模型:让AI学会“记忆“
开发语言·人工智能·深度学习·机器学习