Node.js教程之在IIS7中使用ARR(Application Request Routing)反向代理虚拟目录到Nodejs站点
沉沙 2019-05-15 来源 : 阅读 2280 评论 0

摘要:本篇文章探讨了Node.js教程之在IIS7中使用ARR(Application Request Routing)反向代理虚拟目录到Nodejs站点,希望阅读本篇文章以后大家有所收获,帮助大家对相关内容的理解更加深入。

本篇文章探讨了Node.js教程之在IIS7中使用ARR(Application Request Routing)反向代理虚拟目录到Nodejs站点,希望阅读本篇文章以后大家有所收获,帮助大家对相关内容的理解更加深入。

Node.js教程之在IIS7中使用ARR(Application Request Routing)反向代理虚拟目录到Nodejs站点

<

 目标:
 1.访问www.arrdemo.com/proxy 跳转到 localhost:8898的Nodejs站点
 2.Nodejs站点的页面可以返回到浏览器,包括js,css,图片
 3.Nodejs站点的 res.redirect(‘ ‘) 重定向要正确,包括站内跳转和站外跳转
步骤:
1. 新建站点绑定域名www.arrdemo.com,配置host文件指向本机,新建虚拟目录proxy。  
注意去掉虚拟目录->压缩->"启用动态内容压缩"和“启用静态内容压缩” 前面的勾选。否则会出现如下错误:
HTTP 错误 500.52 - URL Rewrite Module Error.
HTTP 响应的内容已编码(“gzip”)时,无法应用出站重写规则。
  2.启动Nodejs站点 //localhost:8898
  这个站点是《nodejs开发指南》上的microblog实例,学习过程中改成了Express4.13.1版本。
  3.安装ARR,启用Proxy
   下载地址(//www.iis.net/downloads/microsoft/application-request-routing)
  安装完成后,打开IIS->选中服务器名称->双击 右侧功能视图 IIS 节点下的Application Request Routing Cache->点击 右侧操作视图Proxy节点下的Server Proxy Settings->勾选上Enable Proxy前面的复选框
     
 
 
 
 
 4.配置虚拟目录的URL重写规则
  在IIS节点,站点节点,虚拟目录节点都可以配置URL重新规则,并且一级级继承。配置完成后信息保存到对应的web.config文件中。所以如果 www.arrdemo.com部署在多个服务器上,每个服务器的proxy虚拟目录都需要重定向时可以采取拷贝proxy下的web.config文件 的方式快速部署。这里只在proxy虚拟目录下部署,排除继承的影响。
 首先,配置入站规则。把//www.arrdemo.com/proxy/reg 这样的url重写成 //localhost:8898/reg
 
双击"URL重写",从入站规则下选择空白规则模板。剩下的注意细看图片注释:
到这一步正常情况下在浏览器里输入//www.arrdemo.com/proxy,应该可以看到有内容输出了,但是没有任何样式和js效果。如下图:
这是因为入站规则能把请求转发到nodejs里,nodejs返回的html内容再转发到浏览器。但html里的css和js还有图片的路径一般都是相对站点根路径的,不会加上虚拟目录proxy,所以前端看不到任何样式。
这时候该出站规则上场了。。。。。。。
 然后,配置出站规则。把//localhost:8898/bootstrap/..... 这样的url转换成//www.arrdemo.com/proxy/bootstrap/.....
我这里就拿已经配置好的规则演示了。规则多了分先后顺序,如果匹配上了是否”停止处理“很重要。比如:匹配上两个重新类型的规则,那么就会在输出里出现proxy/proxy的情形,导致出错。
第一个规则 bbbb,处理输出的js、css、图片等路径不对问题。
 
做完第一个规则,本应万事大吉,只剩喝酒了。然而。。。。然而。。。。。打开网页登陆后跳转到首页的地址变成了 www.arrdemo.com 没有加上proxy。接着下一规则走起。。。
第二个规则处理res.redirect(‘/‘); 这种站内跳转 
站内跳转需要在输出时添加proxy,主要是检查  {RESPONSE_STATUS} 变量为302, 然后在 重写时输出 /proxy{R:1},规则如下(请细看图):
这样处理后站内跳转的就没问题了。
 
第三个规则处理res.redirect(‘//www.baidu.com‘); 这种站外跳转
  跟第二个规则的区别就是这种跳转不做任何操作,直接抛出,规则如下:
现在再去浏览器里访问一下试试吧,如果还不行,请重启站点。
总结:
1.完整的配置文件奉上
 proxy 下的 web.config
2.查找资料除了百度、必应最应该想到的就是官网帮助文档
每一步操作右侧都有个帮助的链接,点进去是详细的英文文档。
不过也不要完全相信,比如配置重定向跳转时,文档里是这样的:
<outboundRules>
    <!-- This rule changes the domain in the HTTP location header for redirection responses -->
    <rule name="Change Location Header">
        <match serverVariable="RESPONSE_LOCATION" pattern="^//[^/]+/(.*)" />
        <conditions>
            <add input="{RESPONSE_STATUS}" pattern="^301" />
        </conditions>
        <action type="Rewrite" value="//{HTTP_HOST}/{R:1}"/>
    </rule>
</outboundRules>
我明明感觉应该是302啊,这里为什么是301;还有Rewrite 里那么写真的对吗?我不确定,不过也得到一个思路使用RESPONSE_STATUS变量。
微服务、nodejs好像很火的样子,我也在尝试。希望这篇文章可以让node+nginx实现域名解析的人们多一种解决思路 node+iis+arr实现域名解析。
   

      本文由职坐标整理发布,学习更多的相关知识,请关注职坐标IT知识库!

本文由 @沉沙 发布于职坐标。未经许可,禁止转载。
喜欢 | 0 不喜欢 | 0
看完这篇文章有何感觉?已经有0人表态,0%的人喜欢 快给朋友分享吧~
评论(0)
后参与评论

您输入的评论内容中包含违禁敏感词

我知道了

助您圆梦职场 匹配合适岗位
验证码手机号,获得海同独家IT培训资料
选择就业方向:
人工智能物联网
大数据开发/分析
人工智能Python
Java全栈开发
WEB前端+H5

请输入正确的手机号码

请输入正确的验证码

获取验证码

您今天的短信下发次数太多了,明天再试试吧!

提交

我们会在第一时间安排职业规划师联系您!

您也可以联系我们的职业规划师咨询:

小职老师的微信号:z_zhizuobiao
小职老师的微信号:z_zhizuobiao

版权所有 职坐标-一站式IT培训就业服务领导者 沪ICP备13042190号-4
上海海同信息科技有限公司 Copyright ©2015 www.zhizuobiao.com,All Rights Reserved.
 沪公网安备 31011502005948号    

©2015 www.zhizuobiao.com All Rights Reserved

208小时内训课程