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

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


当前回答

我有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......"
}

其他回答

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

Httpbin.org使用这个方法:

return jsonify(origin=request.headers.get('X-Forwarded-For', request.remote_addr))

下面是最简单的解决方案,以及如何在生产中使用。

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

添加include proxy_params到/etc/nginx/sites-available/$project。

  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;

这个应该可以了。 它提供客户端IP地址(远程主机)。

注意,这段代码是在服务器端运行的。

from mod_python import apache

req.get_remote_host(apache.REMOTE_NOLOOKUP)

代理可能会让这有点棘手,如果你正在使用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的文档。您的解决方案可能根据您的特定环境而有所不同。