[英]How to get remote client's IP address in an express based Node JS app running on App-Engine
嘗試獲取IP時,所有標准標頭值都包含不正確的值。
req.ip: ::ffff:172.17.0.5
req.headers['x-forwarded-for']: 169.254.160.2
req.socket.remoteAddress: ::ffff:172.17.0.5
所有這些都會導致IP錯誤。
解決方案:
let ip = req.headers['x-appengine-user-ip']
或 app.set('trust proxy', true);
使用Express的信任代理設置app.set('trust proxy', true);
說明: https : //cloud.google.com/appengine/docs/flexible/nodejs/runtime#https_and_forwarding_proxies
App Engine會在負載均衡器處終止HTTPS連接,並將請求轉發到您的應用程序。 用戶的IP地址在標准
X-Forwarded-For
標頭和X-Appengine-User-Ip
標頭中可用。 需要此信息的應用程序應將其Web框架配置為信任代理。
每個請求的標頭值的完整列表:
{
"host": "<APP_ID>.appspot.com",
"x-real-ip": "169.254.160.2",
"x-forwarded-for": "169.254.160.2",
"x-google-real-ip": "169.254.160.2",
"x-appengine-user-ip": "2620:0:1002:100a:2c4b:4f6b:7851:a9d9",
"x-appengine-api-ticket": "aad4544d4e04a1a0",
"x-appengine-user-email": "",
"x-appengine-auth-domain": "gmail.com",
"x-appengine-user-id": "",
"x-appengine-user-nickname": "",
"x-appengine-user-organization": "",
"x-appengine-user-is-admin": "0",
"x-appengine-request-id-hash": "A104B85B",
"x-appengine-request-log-id": "5748c500ff00ff09eec9a104b85b0001737e736d6172742d737061726b2d39333632320001323031363035323774313530323538000100",
"x-appengine-https": "on",
"x-appengine-datacenter": "us6",
"x-appengine-default-version-hostname": "smart-spark-93622.appspot.com",
"cache-control": "max-age=0",
"accept": "text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8",
"upgrade-insecure-requests": "1",
"save-data": "on",
"user-agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_11_5) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/51.0.2704.63 Safari/537.36",
"accept-language": "en-US,en;q=0.8",
"x-appengine-country": "US",
"x-appengine-region": "ca",
"x-appengine-city": "san francisco",
"x-appengine-citylatlong": "37.774929,-122.419416",
"x-cloud-trace-context": "4a77265a7fa3e11be8cccebce59f7702/9314487514850703289;o=5"
}
可以看到, x-forwarded-for
被設置為x-google-real-ip
。 因此,用戶的ip現在可以在x-appengine-user-ip
。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.