Ngnix反向代理中内容替换
Nginx是一款非常不错高性能的HTTP和反向代理服务器,占用内存少,并发能力强,在同类型的网页服务器中表现一直不错。
最近在做系统反向代理时遇到代理访问时,应用页面中的地址始终是原应用名称地址问题,下面就举例说明下:
实际应用地址:
应用系统1http://192.168.0.1:8080/web
应用系统2 http://192.168.0.2:8080/web
代理服务器地址为:192.168.2.1, 对外开放的端口为:7070
这两个应用是单独的应用,系统不同,通过反向代理系统使用demo1代表应用系统1,demo2代表应用系统2.
开始在nginx配置文件nginx.conf中进行配置,配置如下:
server {
listen 7070;
server_name localhost;
charset utf-8;
location /demo1 {
proxy_set_header Host $host:7070;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_passhttp://192.168.0.1:8080/web;
}
location /demo2 {
proxy_set_header Host $host:7070;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_pass http://192.168.0.2:8080/web;
}
}
配置好后,正常访问可以正常进入登录页面,数据用户名密码后点击登录却发现页面提交请求的地址是错误的。
应该请求的地址:http://192.168.2.1:7070/demo1/login ,但实际请求的地址却变成http://192.168.2.1:7070/web/login
也就是应用名称未被正常替换,尝试了 通过proxy_redirect 进行处理。
配置中增加如下内容:
proxy_redirecthttp://192.168.2.1:7070/web/loginhttp://192.168.2.1:7070/demo1/login;
但发现配置后仍旧无效,说明应用名称在页面中可能有写死或者未被替换情况,于是在网上查询了一下,发现有个第三方模块
nginx_substitutions_filter 此模块作用是替换过滤响应主体,nginx也有一个类似这样的原生模块(http_sub_module),但有一个缺点,就是只能使用一条规则,而nginx_substitutions_filter则不限规则数量(测试效率比原生模块稍慢一点)。
https://github.com/yaoweibin/ngx_http_substitutions_filter_module/
下载该模块后,进入 nginx安装目录 通过./configure --add-module=path/substitutions4nginx-read-only 命令进行了该模块安装。
完成后增加 subs_filter '/web/' '/demo1/';
location /demo1 {
proxy_set_header Host $host:7070;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_passhttp://192.168.0.1:8080/web;
subs_filter '/web/' '/demo1/';
}
至此,请求处理正常。