flask nginx反向代理獲取真實(shí)訪問IP

目標(biāo):
利用nginx實(shí)現(xiàn)server_ip:8080 代理 server_ip:8000
獲取真實(shí)的訪問者IP

1. 修改nginx配置文件

在location ~ {}的大括號內(nèi)添加如下參數(shù)

proxy_set_header Host $host:8080;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header REMOTE-HOST $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
2. flask代碼

將request.remote_addr修改為request.headers['X-Real-Ip']

@flask_login.user_logged_in.connect_via(app)
def _track_logins(sender, user, **extra):
    user.login_count += 1
    #user.login_ip = request.remote_addr
    user.login_ip = request.headers['X-Real-Ip']
    db.session.add(user)
    db.session.commit()
3. 可以嘗試查看請求headers頭信息

在flask代碼中添加print request.headers

X-Real-Ip: 10.0.1.166
Content-Length: 
User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10.12; rv:50.0) Gecko/20100101 Firefox/50.0
Connection: Keep-Alive
Remote-Host: 10.0.1.166
Host: 172.16.3.9
Upgrade-Insecure-Requests: 1
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
Proxy-Connection: Keep-Alive
Accept-Language: zh-CN,zh;q=0.8,en-US;q=0.5,en;q=0.3
X-Forwarded-For: 10.0.1.166
Content-Type: 
Accept-Encoding: gzip, deflate
4. 完整nginx配置文件
events

{

  worker_connections  1024;

}

http{
client_max_body_size 100m;


proxy_cache_path  /tmp/threat levels=1:2 keys_zone=cache1:80m max_size=10000m inactive=60000m;

server_tokens off;

upstream backserver {

  server 127.0.0.1:8080;

  keepalive 15;

}

log_format proxy_combined '$remote_addr [$time_local] "$request" $status $body_bytes_sent $request_time "$upstream_cache_status"';

log_format timed_combined '$http_x_forwarded_for $remote_addr - $remote_user [$time_local] '
    '"$request" $status $body_bytes_sent '
    '"$http_referer" "$http_user_agent" '
    '$request_time $upstream_response_time $pipe';

server {

  listen 8080;
            client_body_buffer_size  128k;
            proxy_connect_timeout    600;
            proxy_read_timeout       600;
            proxy_send_timeout       6000;

  add_header X-Cache $upstream_cache_status;

#不緩存/login頁面
  location =/login{
        proxy_pass http://127.0.0.1:8000;
        proxy_http_version 1.1;
        #proxy_set_header Connection "Keep-Alive";
        #proxy_set_header Proxy-Connection "Keep-Alive";
        access_log /var/log/nginx/proxy_access.log proxy_combined;
        proxy_set_header Host $host:8080;
        proxy_set_header X-Real-Ip $remote_addr;
        proxy_set_header REMOTE-HOST $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  }


  location ~ {
        proxy_cache cache1;
        proxy_cache_valid 200 302 5d;
        proxy_cache_methods GET HEAD POST;
        proxy_cache_key "$request_uri|$request_body";
#只緩存當(dāng)前訪問IP訪問過的頁面暑脆,其他IP訪問該頁面不緩存
#proxy_cache_key "$remote_addr|$request_uri|$request_body";
        proxy_pass http://127.0.0.1:8000;
        proxy_http_version 1.1;
        #proxy_set_header Connection "Keep-Alive";
        #proxy_set_header Proxy-Connection "Keep-Alive";
        access_log /var/log/nginx/proxy_access.log proxy_combined;
        proxy_set_header Host $host:8080;
        proxy_set_header X-Real-Ip $remote_addr;
        proxy_set_header REMOTE-HOST $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  }

}
}

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末饵筑,一起剝皮案震驚了整個濱河市处坪,隨后出現(xiàn)的幾起案子架专,更是在濱河造成了極大的恐慌,老刑警劉巖部脚,帶你破解...
    沈念sama閱讀 206,126評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異丧没,居然都是意外死亡鹰椒,警方通過查閱死者的電腦和手機(jī)漆际,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,254評論 2 382
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來奸汇,“玉大人,你說我怎么就攤上這事擂找。” “怎么了贯涎?”我有些...
    開封第一講書人閱讀 152,445評論 0 341
  • 文/不壞的土叔 我叫張陵慢洋,是天一觀的道長。 經(jīng)常有香客問我且警,道長,這世上最難降的妖魔是什么斑芜? 我笑而不...
    開封第一講書人閱讀 55,185評論 1 278
  • 正文 為了忘掉前任,我火速辦了婚禮杏头,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘醇王。我一直安慰自己,他們只是感情好寓娩,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,178評論 5 371
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著棘伴,像睡著了一般。 火紅的嫁衣襯著肌膚如雪焊夸。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 48,970評論 1 284
  • 那天饭冬,我揣著相機(jī)與錄音使鹅,去河邊找鬼昌抠。 笑死,一個胖子當(dāng)著我的面吹牛扰魂,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播劝评,決...
    沈念sama閱讀 38,276評論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼蒋畜!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起姻成,我...
    開封第一講書人閱讀 36,927評論 0 259
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎均牢,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體才睹,經(jīng)...
    沈念sama閱讀 43,400評論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,883評論 2 323
  • 正文 我和宋清朗相戀三年垮庐,在試婚紗的時候發(fā)現(xiàn)自己被綠了坞琴。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 37,997評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡剧辐,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出荧关,到底是詐尸還是另有隱情,我是刑警寧澤羞酗,帶...
    沈念sama閱讀 33,646評論 4 322
  • 正文 年R本政府宣布紊服,位于F島的核電站胸竞,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏卫枝。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,213評論 3 307
  • 文/蒙蒙 一校赤、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧马篮,春花似錦、人聲如沸浑测。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,204評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至岖圈,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間钙皮,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,423評論 1 260
  • 我被黑心中介騙來泰國打工株灸, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人慌烧。 一個月前我還...
    沈念sama閱讀 45,423評論 2 352
  • 正文 我出身青樓,卻偏偏與公主長得像屹蚊,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子汹粤,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,722評論 2 345

推薦閱讀更多精彩內(nèi)容