出于安全原因,有时需要通过 IP 来阻止用户。就我而言,我想在(SQL)数据库中管理 IP 黑名单。我想我可以根据 Action Composition 处理过滤器部分,但为此我需要用户的 IP。
那么,如何获取用户的IP呢?
PS:该应用程序在 nginx 代理后面运行。
最佳答案
如果你玩!应用程序位于 nginx(或任何其他反向代理)之后,request.remoteAddress()
只会返回你的 nginx 主机的 IP 地址。为了检索客户端的真实 IP,您应该在 nginx 的 proxy_pass 配置中包含以下内容:
location / {
proxy_pass http://play-app:9000;
proxy_set_header X-Real-IP $remote_addr;
}
这会将客户端 IP 作为参数添加到 header 中
文档:Nginx
然后在您的 Play 中!应用程序,你会像这样检索它:
request.headers.get("X-Real-IP") //In Java
request.headers.get("X-Real-IP") //In Scala
文档:Java , Scala
关于nginx - 如何在 Play Framework 2 中获取用户的 IP?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11207654/