1. 目的

  • 通过nginx实现代理,前端HTML5只需要对接一个http端口,即可与后台多个二级http服务进行对接,方法是在nginx中通过不同的路径代理不同的二级http服务。
  • 静态页面依然使用nginx一级服务器返回。

2.Nginx服务器配置

配置nginx,访问路径为button1时转发到3002端口,访问路径为button2时转发到3003端口。

server {
        listen       8081;
        server_name  localhost;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;
		
		location / {
            root   html;
			index  index.html index.htm;
        }
        location /button1 {
            proxy_pass   http://127.0.0.1:3002;
        }
		location /button2 {
            proxy_pass   http://127.0.0.1:3003;
        }

3. ngnix静态网页编写

ngnix中静态文件目录

nginx 反向代理 二级目录下的html静态页 nginx二级目录跳转_php

index.html文件代码

<form action="http://127.0.0.1:8081/button1/login.php" method="post">
    <input type="submit"/>
</form>
<form action="http://127.0.0.1:8081/button2/login.php" method="post">
    <input type="submit"/>
</form>

4. 二级服务器搭建

使用nodejs搭建两个http服务器,分别监听3002、3003端口,代码如下:

// 1. 加载http核心模块
let http = require("http");

// 2. 使用http.createServer()方法创建一个web服务器,通过server接收
let server = http.createServer();

// 3. 服务器要做的事:提供服务,发送、接收、处理请求,并发送响应
/** server.on注册request请求事件,客户端请求时会自动触发服务器的request请求事件;
	回调函数对请求进行处理,参数介绍:
	req提供了请求的详细信息。通过它可以访问请求头和请求的数据.
	res用于构造要返回给客户端的数据。
*/
server.on("request", function (req, res) {
  // 这里的回调事件根据需要编写即可,这里给出简单示例
    
  // 3.1 收到请求时,打印请求的路径
  console.log(`收到客户端的请求了,请求路径是${req.url}`);
  // 3.2 设置响应头中的Content-Type为plain普通文本模式,否则中文无法正常展示
  res.setHeader("Content-Type", "text/plain; charset=utf-8");
  let url = req.url;
  // 3.3 根据不同的url展示不同内容
  if (url == "/") {
    // res.write--在页面内写入内容 
    res.write("首页");
  } else if (url == "/login") {
    res.write("登录");
  }
});
// 4.绑定端口号;
server.listen(3002, function () {
  console.log("服务器启动成功,可以通过http:127.0.0.1:3002/来进行访问");
});

服务器文件目录:

nginx 反向代理 二级目录下的html静态页 nginx二级目录跳转_服务器_02

在命令行运行两个服务

nginx 反向代理 二级目录下的html静态页 nginx二级目录跳转_html_03

nginx 反向代理 二级目录下的html静态页 nginx二级目录跳转_运维_04

 5. 测试验证

浏览器打开显示效果如下,该页面使用ngnix返回html/index.html文件

nginx 反向代理 二级目录下的html静态页 nginx二级目录跳转_运维_05

 点击第1个按钮,消息转发到3002服务,点击第2个按钮消息转发到3003服务

nginx 反向代理 二级目录下的html静态页 nginx二级目录跳转_运维_06

nginx 反向代理 二级目录下的html静态页 nginx二级目录跳转_php_07

6. proxy_pass设置

proxy_pass代理地址端口后无任何字符,转发后地址:代理地址+访问URL目录部分

proxy_pass代理地址端口后有目录(包括 / ),转发后地址:代理地址+访问URL目录部分去除location匹配目录(示例中的"v1"或"v1/")

代理地址为 http://127.0.0.1:3002

按钮(http://127.0.0.1:8081/button1/login.php)URL目录地址为:button1/test/login.php

因此以下没有加/ 的访问地址为:http://127.0.0.1:3002/button1/login.php

location /button1 {
     proxy_pass   http://127.0.0.1:3002;
 }

以下加/的访问地址为: http://127.0.0.1:3002/login.php

location /button1 {
     proxy_pass   http://127.0.0.1:3002/;
}

实际测试如下:

nginx 反向代理 二级目录下的html静态页 nginx二级目录跳转_php_08