请参阅如何访问请求对象的文档,然后从同一请求对象中获取属性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文档。
代理可能会让这变得有点棘手,请确保查看ProxyFix(Flask文档)如果您正在使用代理,则请查看特定环境中的request.environ
。对于nginx,我有时会做这样的事情:
from flask import request
request.environ.get('HTTP_X_REAL_IP', request.remote_addr)
当代理服务器(如nginx)转发地址时,它们通常会在请求头中的某个地方包含原始IP。
更新 请查看flask-security的实现。请务必在实施之前查阅ProxyFix文档。根据您特定的环境,您的解决方案可能会有所不同。
实际上,你会发现只需获取以下内容即可获得服务器地址:
request.remote_addr
如果你想获取客户端的IP地址,可以使用以下代码:
request.environ['REMOTE_ADDR']
以下代码总是给出客户端的公共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
我有 Nginx,以下是我的Nginx配置:
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地址:
from flask import request
print(request.remote_addr)
httpbin.org 使用了这种方法:
return jsonify(origin=request.headers.get('X-Forwarded-For', request.remote_addr))
127.0.0.1
,并不是很有用。 - Uri Goren如果您在其他负载均衡器(例如AWS应用程序负载均衡器)后面使用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
以下是最简单的解决方案,以及如何在生产中使用。
from flask import Flask, request
from werkzeug.middleware.proxy_fix import ProxyFix
app = Flask(__name__)
# Set environment from any X-Forwarded-For headers if proxy is configured properly
app.wsgi_app = ProxyFix(app.wsgi_app, x_host=1)
@app.before_request
def before_process():
ip_address = request.remote_addr
/etc/nginx/sites-available/$project
中添加include proxy_params
。 location / {
proxy_pass http://unix:$project_dir/gunicorn.sock;
include proxy_params;
}
include proxy_params
包含了一些被ProxyFix解析的头信息并进行转发。
$ sudo cat /etc/nginx/proxy_params
proxy_set_header Host $http_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;
addr_ip4 = request.remote_addr
HTTP_X_FORWARDED_FOR
下发送真实IP地址,因此确保您不会在每个请求中得到本地主机。 - Rasty Turek