Pythonを使用する(Werkzeugに基づく)Flaskマイクロフレームワーク(私の場合は2.6)を使用して、ユーザーがログオンしてファイルをダウンロードできるWebサイトを作成しています。
ユーザーがログオンするときに(ログの目的で)ユーザーのIPアドレスを取得する必要があります。誰でもこれを行う方法を知っていますか?確かにPythonでそれを行う方法はありますか?
Pythonを使用する(Werkzeugに基づく)Flaskマイクロフレームワーク(私の場合は2.6)を使用して、ユーザーがログオンしてファイルをダウンロードできるWebサイトを作成しています。
ユーザーがログオンするときに(ログの目的で)ユーザーのIPアドレスを取得する必要があります。誰でもこれを行う方法を知っていますか?確かにPythonでそれを行う方法はありますか?
回答:
Requestオブジェクトにアクセスして、この同じRequestオブジェクトである属性から取得する方法に関するドキュメントを参照してくださいremote_addr
。
コード例
from flask import request
from flask import jsonify
@app.route("/get_my_ip", methods=["GET"])
def get_my_ip():
return jsonify({'ip': request.remote_addr}), 200
詳細については、Werkzeugのドキュメントを参照してください。
HTTP_X_FORWARDED_FOR
ので、リクエストごとにlocalhostになっていないことを確認してください。
プロキシはこれを少しトリッキーにする可能性があります。使用している場合は必ずProxyFix(Flask docs)をチェックしてください。request.environ
特定の環境で見てください。nginxでは、私は時々このようなことをします:
from flask import request
request.environ.get('HTTP_X_REAL_IP', request.remote_addr)
nginxなどのプロキシがアドレスを転送する場合、通常、リクエストヘッダーのどこかに元のIPが含まれます。
更新 フラスコのセキュリティの実装を参照してください。ここでも、実装する前にProxyFixに関するドキュメントを確認してください。ソリューションは、特定の環境によって異なる場合があります。
実際、あなたが見つけるのは、単に以下を取得すると、サーバーのアドレスが取得されるということです。
request.remote_addr
クライアントのIPアドレスが必要な場合は、以下を使用します。
request.environ['REMOTE_ADDR']
request.remote_addr
リバースプロキシが信頼されているかどうかによって、リモートアドレスを取得する必要があるプロパティのように聞こえます。
ユーザーのIPアドレスは、次のスニペットを使用して取得できます。
from flask import request
print(request.remote_addr)
私はNginxとNginx Config以下を持っています:
server {
listen 80;
server_name xxxxxx;
location / {
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_pass http://x.x.x.x:8000;
}
}
@ tirtha-rソリューションが私のために働いた
#!flask/bin/python
from flask import Flask, jsonify, request
app = Flask(__name__)
@app.route('/', methods=['GET'])
def get_tasks():
if request.environ.get('HTTP_X_FORWARDED_FOR') is None:
return jsonify({'ip': request.environ['REMOTE_ADDR']}), 200
else:
return jsonify({'ip': request.environ['HTTP_X_FORWARDED_FOR']}), 200
if __name__ == '__main__':
app.run(debug=True,host='0.0.0.0', port=8000)
私の要求と応答:
curl -X GET http://test.api
{
"ip": "Client Ip......"
}
以下のコードは常にクライアントのパブリックIPを提供します(プロキシの背後にあるプライベートIPではありません)。
from flask import request
if request.environ.get('HTTP_X_FORWARDED_FOR') is None:
print(request.environ['REMOTE_ADDR'])
else:
print(request.environ['HTTP_X_FORWARDED_FOR']) # if behind a proxy
httpbin.orgはこの方法を使用します:
return jsonify(origin=request.headers.get('X-Forwarded-For', request.remote_addr))
127.0.0.1
プロキシによる返品、あまり役に立ちません。
AWS Application Balancerなどの他のバランサーの背後でNginxを使用する場合、HTTP_X_FORWARDED_FORはアドレスのリストを返します。それはそのように修正できます:
if 'X-Forwarded-For' in request.headers:
proxy_data = request.headers['X-Forwarded-For']
ip_list = proxy_data.split(',')
user_ip = ip_list[0] # first address in list is User IP
else:
user_ip = request.remote_addr # For local development
GunicornおよびNginx環境を使用している場合は、次のコードテンプレートが役立ちます。
addr_ip4 = request.remote_addr