亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

nginx如何配置x-forwarded-for頭部

瀏覽:120日期:2023-03-13 15:37:48
目錄
  • nginx配置x-forwarded-for頭部
  • 這里配置了nginx的監(jiān)聽端口為50001
  • 總結

nginx配置x-forwarded-for頭部

本地用tomcat起了一個j2ee的應用,然后又起了一個nginx做反向代理。

nginx.conf:

 #user  nobody;worker_processes  1; #error_log  logs/error.log;#error_log  logs/error.log  notice;#error_log  logs/error.log  info; #pidlogs/nginx.pid;  events {    worker_connections  1024;}  http {    include       mime.types;    default_type  application/octet-stream;     #log_format  main  "$remote_addr - $remote_user [$time_local] "$request" "    #  "$status $body_bytes_sent "$http_referer" "    #  ""$http_user_agent" "$http_x_forwarded_for"";     #access_log  logs/access.log  main;     sendfileon;    #tcp_nopush     on;     #keepalive_timeout  0;    keepalive_timeout  65;     #gzip  on;     server {listen       50001;server_name  localhost; #charset koi8-r; #access_log  logs/host.access.log  main; location / {    root   html;    index  index.html index.htm;} location /ly {    proxy_pass   http://127.0.0.1:8080/hello.do;    proxy_set_header    Host $host;      proxy_set_header    X-real-ip $remote_addr;      proxy_set_header    X-Forwarded-For $proxy_add_x_forwarded_for;  }     #error_page  404      /404.html; # redirect server error pages to the static page /50x.html#error_page   500 502 503 504  /50x.html;location = /50x.html {    root   html;}    }    include servers/*;}

這里配置了nginx的監(jiān)聽端口為50001

使用了proxy_set_header來配置nginx轉發(fā)的頭部操作。

其中如下配置就是針對xff的:

其中$proxy_add_x_forwarded_for變量的值是當前包的x-forwarded-for變量和remote-addr變量,使用逗號隔開。

所以上面的命令就是把當前的包的x-forwarded-for的值設置為x-forwarded-for和remote-addr的連接。

這樣這個包轉發(fā)給下游時,下游就有了這臺nginx服務器的ip地址。

當client第一次請求nginx服務器時,nginx拿到的x-forwarded-for為null,remote-addr就是client的實際地址,所以第一次的轉發(fā)的xff值就只有client的ip地址,轉發(fā)的nginx的地址是在remote-addr里。

下一臺nginx服務器會把第一臺nginx服務器的地址填入xff。

所以當一臺服務器收到一個包時,上一臺服務器的地址并不在xff里面,必須通過remote-addr拿到。

Controller:

public class MainController extends HttpServlet {     public void doGet(HttpServletRequest request,      HttpServletResponse response)    throws ServletException, IOException    {PrintWriter out = response.getWriter();out.println("NGINX FORWARD");String ssfAddr = request.getHeader("X-Forwarded-For"); String realIp = request.getHeader("X-Real-IP"); String remoteAddr = request.getRemoteAddr(); System.out.println("X-Forwarded-For: " + ssfAddr);System.out.println("X-Real-IP: " + realIp);System.out.println("remoteAddr: " + remoteAddr);     } }

本地ip為192.168.43.33。

然后我先使用了手機訪問了nginx域名:192.168.43.33:50001/ly

顯示:

X-Forwarded-For: 192.168.43.1X-Real-IP: 192.168.43.1remoteAddr: 127.0.0.1

這里192.168.43.1是手機的ip,127.0.0.1是nginx的ip。且通過x-real-ip可以獲取到真實ip。

在使用一個crul命令:

curl http://localhost:50001/ly -H "X-Forwarded-For: unkonw, <8.8.8.8> 1.1.1.1" -H "X-Real-IP: 2.2.2.2"

顯示:

X-Forwarded-For: unkonw, <8.8.8.8> 1.1.1.1, 127.0.0.1X-Real-IP: 127.0.0.1remoteAddr: 127.0.0.1

這里客戶端就是本機,所以會在xff后面添加一個127.0.0.1。也是符合預期的。

總結

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持。

標簽: Nginx
主站蜘蛛池模板: 欧美成人v视频免费看 | 美国特黄特色的免费大片 | 欧美亚洲国产色综合 | 久久久久久久久综合影视网 | 国产在线观看入口 | 欧美一级做一级做片性十三 | 麻豆成人传媒一区二区 | 精品免费久久久久久成人影院 | 久久久久国产一级毛片高清版 | 深夜偷偷看视频在线观看 | s级毛片 | 韩国xxxxxxxx69| 午夜国产视频 | 99久久国产综合精品2020 | 黄色短视频在线播放 | 国产一区二区三区在线观看影院 | 国产1区2区三区不卡 | 精品国产亚一区二区三区 | a在线免费观看视频 | 色综合图区 | 欧美一级在线视频 | 久草在线中文 | 国产区香蕉精品系列在线观看不卡 | 欧美黄三级在线观看 | 拍拍拍拍拍拍拍无挡大全免费 | 国产老肥妇视频 | 狠狠操精品视频 | 最新国产精品自拍 | 色老头oldmanvideos | 高清中文字幕视频在线播 | 欧美黄三级在线观看 | 孕交欧美videos | 午夜视频吧 | 亚洲热热久久九九精品 | 九九免费观看全部免费视频 | 午夜色a大片在线观看免费 午夜色图 | 欧美洲久久日韩欧美 | 国产麻豆网站 | 国产三级在线观看a | 亚洲国产精品毛片∧v卡在线 | 高h文bl |