加入收藏 | 设为首页 | 会员中心 | 我要投稿 南平站长网 (https://www.0599zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长资讯 > 外闻 > 正文

一段万能的Nginx接口实现反向代理配置值得收藏!

发布时间:2019-05-11 17:28:12 所属栏目:外闻 来源:今日头条
导读:副标题#e# 什么是代理服务器 代理服务器,客户机在发送请求时,不会直接发送给目的主机,而是先发送给代理服务器,代理服务接受客户机请求之后,再向主机发出,并接收目的主机返回的数据,存放在代理服务器的硬盘中,再发送给客户机。 为什么要使用代理服务

如果是打包工具生成增这个配置的话,可以用nodejs动态获取你电脑的ip

  1. function getIPAdress() {  
  2.  var interfaces = require('os').networkInterfaces();  
  3.  for (var devName in interfaces) {  
  4.  var iface = interfaces[devName];  
  5.  for (var i = 0; i < iface.length; i++) {  
  6.  var alias = iface[i];  
  7.  if (alias.family === 'IPv4' && alias.address !== '127.0.0.1' && !alias.internal) {  
  8.  return alias.address; 
  9.  }  
  10.  }  
  11.  }  

所以,这里贴出来一个动态生成nginx.config的工具

  1. function buildNginxConfig(config) { 
  2.   
  3.  function getIPAdress() {  
  4.  var interfaces = require('os').networkInterfaces();  
  5.  for (var devName in interfaces) {  
  6.  var iface = interfaces[devName];  
  7.  for (var i = 0; i < iface.length; i++) {  
  8.  var alias = iface[i];  
  9.  if (alias.family === 'IPv4' && alias.address !== '127.0.0.1' && !alias.internal) {  
  10.  return alias.address;  
  11.  }  
  12.  }  
  13.  }  
  14.  } 
  15.  var cwd = process.cwd().replace(//g, '/') + '/app'; 
  16.  var protocol = /https|443/.test(config.ip) ? 'https' : 'http'; 
  17.   
  18.  var servers = [{ 
  19.  browserIp: 'localhost', 
  20.  port: 80, 
  21.  root: cwd, 
  22.  serverIp: config.ip, 
  23.  protocol: protocol, 
  24.  }, { 
  25.  browserIp: getIPAdress(), 
  26.  port: 8080, 
  27.  root: cwd, 
  28.  serverIp: config.ip, 
  29.  protocol: protocol, 
  30.  }].map(function(item) { 
  31.  return ` 
  32.  server { 
  33.  listen ${item.port}; 
  34.  server_name ${item.browserIp}; 
  35.   
  36.  location =/ { 
  37.  add_header X-Frame-Options SAMEORIGIN; 
  38.  root ${item.root}; 
  39.  index index.html; 
  40.  } 
  41.   
  42.  location ~* .(html|htm|gif|jpg|jpeg|bmp|png|ico|txt|js|css|swf|woff|woff2|ttf|json|svg|cur|vue|otf|eot)$ { 
  43.  charset utf-8; 
  44.  root ${item.root}; 
  45.  expires 3d; 
  46.  } 
  47.   
  48.  location = /socket/v2 { 
  49.  proxy_pass ${item.protocol}://${item.serverIp}; 
  50.  proxy_redirect off; 
  51.  proxy_http_version 1.1; 
  52.  proxy_set_header Upgrade $http_upgrade; 
  53.  proxy_set_header Connection "upgrade"; 
  54.  proxy_set_header Host ${item.serverIp}; 
  55.  proxy_set_header X-Real-IP $remote_addr; 
  56.  proxy_set_header REMOTE-HOST $remote_addr; 
  57.  proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; 
  58.  proxy_connect_timeout 30; 
  59.  proxy_send_timeout 30; 
  60.  proxy_read_timeout 60; 
  61.  proxy_buffer_size 256k; 
  62.  proxy_buffers 4 256k; 
  63.  } 
  64.   
  65.  location / { 
  66.  proxy_pass ${item.protocol}://${item.serverIp}; 
  67.  proxy_set_header Cookie $http_cookie; 
  68.  proxy_cookie_domain ${item.serverIp} ${item.browserIp}; 
  69.  proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; 
  70.  proxy_set_header Host ${item.serverIp}; 
  71.  proxy_set_header X-Real-IP $remote_addr; 
  72.  proxy_set_header REMOTE-HOST $remote_addr; 
  73.  } 
  74.  }`; 
  75.  }).join(' 
  76. '); 
  77.  var str = `worker_processes 1; 
  78. events { 
  79.  worker_connections 1024; 
  80. http { 
  81.  include mime.types; 
  82.  default_type application/octet-stream; 
  83.  sendfile on; 
  84.  keepalive_timeout 10; 
  85.  ${servers} 
  86. }`; 
  87.   
  88.  return str; 
  89.   
  90. exports = module.exports = buildNginxConfig; 

有了这个万能反向代理,可以随心所欲的玩转任何网站接口了。

(编辑:南平站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

热点阅读