VUE项目IIS部署使用nginx代理访问后端接口方式

 更新时间:2025年12月25日 09:15:37   作者:-清欢有味  
文章浏览阅读704次。文章讲述了项目使用vue-element-admin遇到的跨域问题,尝试了浏览器JS、打包路径、路由模式和IIS代理等方法均无效,最终通过配置Nginx进行后端接口代理解决了问题,同时提供了参考文档链接。

VUE IIS部署使用nginx代理访问后端接口

项目使用 vue-element-admin 方案,采用History模式打包后部署在IIS,在访问接口时状态返回200,但是响应提示

We're sorry but Vue Admin Template doesn't work properly without JavaScript enabled. Please enable it to continue.

搜索发现可能的原因

1.浏览器JS未启用

2.vue项目打包路径有问题

3.vue路由模式需要改成hash模式

4.接口代理问题

已经尝试方法

浏览器JS已经启用,

尝试修改publicPath 从 "./"  "/"  "/xx/"  都无法解决这个问题

尝试将vue路由模式由history修改为hash模式也无法正常访问接口

尝试使用IIS 的ARR代理接口,仍无法解决(这个方法可能是我没有弄明白)

最终解决办法

使用nginx代理后端接口,配置如下

    server {
        listen 8888;
        server_name localhost;
        location / {
            #try_files $uri $uri/  /index.html;  # 解决页面刷新
            proxy_pass http://200.200.200.200:200; #web在IIS的部署地址
            proxy_set_header Host $host;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        }
        location /api1{
            rewrite  ^/api1/(.*)$ /$1 break;
            proxy_pass http://100.100.100.100:100;#api1的后端接口地址
            proxy_set_header Host $host;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        }
        location /api2{
            rewrite  ^/api2/(.*)$ /$1 break;
            proxy_pass https://xxxx.xxxxx.com; #api2的后端接口地址
            proxy_pass_header X-Accel-Buffering;            
            proxy_read_timeout 1800s;
            proxy_set_header Origanization-Id qiancheng;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            proxy_set_header Host xxxx.xxxxx.com;
            #不加下面这些 在https 报403错误
            proxy_ssl_server_name on; 
            proxy_ssl_name xxxx.xxxxx.com;

        }

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • 在vue中阻止浏览器后退的实例

    在vue中阻止浏览器后退的实例

    今天小编就为大家分享一篇在vue中阻止浏览器后退的实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-11-11
  • vue中正确使用jsx语法的姿势分享

    vue中正确使用jsx语法的姿势分享

    这篇文章主要给大家介绍了关于vue中正确使用jsx的相关资料,JSX就是Javascript和XML结合的一种格式,React发明了JSX,利用HTML语法来创建虚拟DOM,当遇到<,JSX就当HTML解析,遇到{就当JavaScript解析,需要的朋友可以参考下
    2021-07-07
  • vue3 setup访问子组件的 DOM 元素的示例代码

    vue3 setup访问子组件的 DOM 元素的示例代码

    使用setup的情况下这个时候我们无法使用this,注意在setup中setup是封闭的,不会将子组件事件暴露出来,所以要用defineExpose(),这篇文章主要介绍了vue3 setup访问子组件的 DOM 元素,需要的朋友可以参考下
    2023-08-08
  • Vue中router-link如何添加mouseover提示

    Vue中router-link如何添加mouseover提示

    这篇文章主要介绍了Vue中router-link如何添加mouseover提示,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-11-11
  • 图文介绍Vue父组件向子组件传值

    图文介绍Vue父组件向子组件传值

    本文通过实例代码给大家详细分享了Vue父组件向子组件传值的过程以及关键点讲解,一起学习参考下吧。
    2018-02-02
  • Vue封装svg-icon组件使用教程

    Vue封装svg-icon组件使用教程

    SVG(Scalable Vector Graphics)可缩放矢量图形,是一种用于描述基于二维的矢量图形的 XML 标记语言,其基本矢量显示对象包括矩形、圆、椭圆、多边形、直线、任意曲线等,还能显示文字对象和嵌入式外部图像
    2023-02-02
  • vue中使用iframe嵌入网页,页面可自适应问题

    vue中使用iframe嵌入网页,页面可自适应问题

    这篇文章主要介绍了vue中使用iframe嵌入网页,页面可自适应问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-09-09
  • Vue3实现动态面包屑的代码示例

    Vue3实现动态面包屑的代码示例

    这篇文章主要给大家介绍一下Vue3动态面包屑是如何实现的,实现思路又是什么,以及发给大家介绍一下面包屑的功能,文章通过代码示例介绍的非常详细,需要的朋友可以参考下
    2023-07-07
  • vue部署到线上为啥会出现404的原因分析及解决

    vue部署到线上为啥会出现404的原因分析及解决

    这篇文章主要介绍了vue部署到线上为啥会出现404的原因分析及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2025-04-04
  • Vue实现动态控制表格列的显示和隐藏

    Vue实现动态控制表格列的显示和隐藏

    这篇文章主要为大家详细介绍了Vue实现动态控制表格列的显示和隐藏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-04-04

最新评论