码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 解决 vite 4 开发环境和生产环境打包后空白、配置axios跨域、nginx代理本地后端接口问题


    1、解决打包本地无法访问空白 

    首先是pnpm  build 打包后直接在dist访问,是访问不了的,需要开启服务

    终端输入 npm install -g serve  然后再输入 serve -s dist  就可以访问了

     但要保证 路由模式是:createWebHashHistory

     和vite.conffig.js中添加 

    2、解决配置axios跨域

     首先

    前端请求地址:http://localhost/api/employee/login

    后端接口地址:http://localhost:8080/admin/employee/login

    npm run dev 后前端是无法请求到后端接口的 

    首先在根下 新建.env.development 和 .env.production  环境变量和模式 | Vite 官方中文文档 (vitejs.dev)这里有解释

    1. # .env.development
    2. VITE_API_BASE_URL=http://localhost:8888/api
    1. # .env.production
    2. VITE_API_BASE_URL=http://localhost/api

    然后在vite.config.js中添加

    1. server: {
    2. host: '0.0.0.0',
    3. port: 8888, //这里的端口跟配置开发环境文件# .env.development的端口要一致
    4. proxy: {
    5. '/api': {
    6. target: 'http://localhost:8080',//这里是后端的接口
    7. changeOrigin: true,
    8. rewrite: (path) => path.replace(/^\/api/, '/admin')
    9. }
    10. }
    11. },

    在request.js中 添加 

    baseURL: import.meta.env.VITE_API_BASE_URL,

     同时按需导出的baseURL也不需要了

    3、nginx 代理跨域 

    配置上面的之后还有配置ngxin  下载合适版本nginx:下载

     下载后放在没有中文的目录中

    找到配置文件

    在配置文件中

    1. location / {
    2. root html/dist; //这里是你打包生产环境的包地址
    3. index index.html index.htm;
    4. }
    5. #error_page 404 /404.html;
    6. # redirect server error pages to the static page /50x.html
    7. #
    8. error_page 500 502 503 504 /50x.html;
    9. location = /50x.html {
    10. root html;
    11. }
    12. # 反向代理
    13. location /api/ {
    14. proxy_pass http://localhost:8080/admin/;
    15. #proxy_pass http://webservers/admin/;
    16. }

     重启nginx就可以了 

    开发环境 pnpm dev 后 前端请求

    反向代理 就可以请求到后端的 8080/admin  了

    生产环境 通过pnpm build  项目中就多了 dist 文件夹 ,将它复制到nginx html下 

    点击nginx.exe   在浏览器中输入localhsot 就能访问前端代码  当然前提你nginx配置的就是80 也可以是其他端口 , 要跟生产环境配置文件的 端口一致

     此时请求地址是

    这样通过反向代理就可以 请求到后端数据。

  • 相关阅读:
    故障演练的关键要素及重要性
    设计模式之代理模式的懂静态代理和动态代理
    【R语言数据科学】:机器学习常见评估指标
    HDU - 2859 Phalanx(DP)
    阿里云的应用型负载均衡,网络型负载均衡,传统型负载均衡
    12、FPGA程序的固化和下载
    buuctf-[网鼎杯 2020 朱雀组]phpweb
    实战计算机网络02——物理层
    UE4(unreal engine)虚幻引擎中安装light explorer灯光管理器插件
    字节跳动面经——图形图像算法实习
  • 原文地址:https://blog.csdn.net/ClearloveYt/article/details/134462707
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号