跨境派

跨境派

跨境派,专注跨境行业新闻资讯、跨境电商知识分享!

当前位置:首页 > 工具系统 > 运营工具 > vue项目使用vite设置proxy代理,vite.config.js配置,解决本地跨域问题

vue项目使用vite设置proxy代理,vite.config.js配置,解决本地跨域问题

时间:2024-03-27 12:31:25 来源:网络cs 作者:欧阳逸 栏目:运营工具 阅读:

标签: 本地  解决  配置  使用  项目  设置  代理 

vue3+vite4项目,配置代理实现本地开发跨域问题

非同源请求,也就是协议(protocol)、端口(port)、主机(host)其中一项不相同的时候,这时候就会产生跨域

vite的proxy代理和vue-cli的proxy大致相同,需要在vite.config.js文件中配置(打包配置也在此)代理配置在server中,可以上vite官网服务器选项查看server.proxy代码示例:开发服务器选项–server.proxy需要注意:使用了代理之后,axios的base路径需要改成代理路径,比如
在这里插入图片描述ok 直接贴配置代码:
import { fileURLToPath, URL } from 'node:url'import { defineConfig } from 'vite'import vue from '@vitejs/plugin-vue'import fs from "fs"// https://vitejs.dev/config/export default defineConfig({  base: './', //相对路径  plugins: [vue()],  resolve: {    alias: {      '@': fileURLToPath(new URL('./src', import.meta.url))    }  },  css: {    preprocessorOptions: {      less: {        modifyVars: {},        javascriptEnabled: true,      },    },  },  build: {    minify:'terser',    outDir: "./dist",    //emptyOutDir: true,    //assetsDir: "assets", //指定静态资源存放路径    // sourcemap: false, //是否构建source map 文件    terserOptions: {      // 生产环境移除console      compress: {        drop_console: false,        drop_debugger: true,      },    },    // 块大小警告的限制(以 kbs 为单位) 默认: 500    chunkSizeWarningLimit: 1000,    // 分解块,将大块分解成更小的块    rollupOptions: {      output: {        manualChunks(id) {          if (id.includes('node_modules')) {            return id.toString().split('node_modules/')[1].split('/')[0].toString();          }        },        chunkFileNames: (chunkInfo) => {          const facadeModuleId = chunkInfo.facadeModuleId            ? chunkInfo.facadeModuleId.split('/')            : [];          const fileName = facadeModuleId[facadeModuleId.length - 2] || '[name]';          return `js/${fileName}/[name].[hash].js`;        }      }    },  },  server: {  // 配置https代理与证书    https: {      key: fs.readFileSync('cert/8982715__nsfocus.com.key'),      cert: fs.readFileSync('cert/8982715__nsfocus.com.pem')    },// 是否开启 https    open: false, // 是否自动在浏览器打开    port: 8899, // 端口号    host: "0.0.0.0",    //这里的ip和端口是前端项目的;下面为需要跨域访问后端项目    proxy: {      '/seatsapi/': {   // '/api'是代理标识,用于告诉node,url前面是/api的就是使用代理的        target: 'https://miccdev.nsfocus.com/',//这里填入你要请求的接口的前缀        ws: false,//代理websocked        changeOrigin: true,  //是否跨域        secure: true,  //是否https接口        // pathRewrite:{  // pathRewrite 的作用是把实际Request Url中的'/api'用""代替        //   "^/": "/"        // },      //   headers: {      //     referer: 'https://uat.nsfocus.com/api/input_suggest', //这里后端做了拒绝策略限制,请求头必须携带referer,否则无法访问后台      //   }      }    }  },})

结束,总结完毕 ~ 简单易懂 ~

本文链接:https://www.kjpai.cn/news/2024-03-27/149418.html,文章来源:网络cs,作者:欧阳逸,版权归作者所有,如需转载请注明来源和作者,否则将追究法律责任!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。

文章评论