• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    迪恩网络公众号

ASP.NETCoreWebApi+Vue前后端分离的iis部署

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

  随着ASP.NET Core的日益完善,本人也想把他用于日后的生成环境中,所以现在自己的学习项目中体验了一把,项目采用的是ASP.NET Core WebApi+Vue+element开发的一个后台管理系统。平时运行的时候都是通过vs启动 IIS Express来发布后端api,前台ui则通过nodejs进行部署。最近尝试把系统部署到 IIS,可在部署的过程中遇到许多的问题,所以特此记录。

1.后台webapi的部署

具体的部署步骤就不细说了,这里有两点需要注意:

第一:由于系统采用的目标框架是 .NET Core 3.1 所以对于应用程序池的 .NET CLR版本要选择无托管代码

 

 

 第二:在webconfig中指定处理程序

百度出来的教程基本只提到第一点中的设置,所以要是发布一直步成功可以检测下是不是少了下面的配置呢。

 

 

 

 2.前台UI的部署

由于采用的是前后台分离的模式所以涉及到了跨域,在node下跨域是通过vue.config进行处理的配置如下(端口88是后台webapi的部署端口)

 

 

 node会将所有api和swagger开头的请求代理到88端口。但是部署到IIS后所有对api的请求都返回了404,怎么这个代理就失败了呢,通过查阅vue.config的官方文档才找到了原因,这个代理只有在开发环境下才生效。

 

 

 那在IIS中怎么将请求代理到88的webapi呢?那就是通过url重写来实现。

下载 URL Rewrite

下载 Application Request Routing

启用ARR

(1)进入ARR设置

 

(2)进入代理设置

 

 (3)启用代理

 

 URL重写设置

(1)进入URL重写设置

 

 (2)添加规则

 

 (3)选中空白规则

 

 (4)设置匹配模式

 

 (5)设置操作

提示{R:2}的意思请参考这篇博文:详解IIS中的重写工具下关于操作重定向URL中的{R:N}与{C:N}

 

至此前台的发布也已配置完毕所有以 http://localhost:89/api/开头的请求都会被重写到88端口。

 


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
asp.net中关于静态变量的生命周期和线程安全发布时间:2022-07-10
下一篇:
ASP.NET通过HTML的上传文件标签来上传文件发布时间:2022-07-10
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap