我正在做一个网站,用户可以登录和下载文件,使用Flask微框架(基于Werkzeug),它使用Python(在我的情况下是2.6)。

我需要在用户登录时获得用户的IP地址(用于登录目的)。 有人知道怎么做吗?肯定有一种方法可以用Python来实现吗?


当前回答

如果你在其他平衡器后面使用Nginx,例如AWS Application balancer, 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

其他回答

请参阅文档,了解如何访问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文档。

如果你在其他平衡器后面使用Nginx,例如AWS Application balancer, 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

下面的代码总是给出客户端的公共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

代理可能会让这有点棘手,如果你正在使用ProxyFix (Flask docs),一定要检查一下。看一下request。在您特定的环境中环境。使用nginx,我有时会这样做:

from flask import request   
request.environ.get('HTTP_X_REAL_IP', request.remote_addr)   

当代理(如nginx)转发地址时,它们通常在请求头中包含原始IP。

更新参见flask-security实现。同样,在实现ProxyFix之前,请查看有关ProxyFix的文档。您的解决方案可能根据您的特定环境而有所不同。

实际上,你会发现,当简单地获取以下信息时,你会得到服务器的地址:

request.remote_addr

如果你想要客户端的IP地址,那么使用下面的方法:

request.environ['REMOTE_ADDR']