Якщо ви знаходитесь під балансиром навантаження, Laravel \Request::ip()
завжди повертає IP-адресу балансира:
echo $request->ip();
// server ip
echo \Request::ip();
// server ip
echo \request()->ip();
// server ip
echo $this->getIp(); //see the method below
// clent ip
Цей спеціальний метод повертає реальний клієнт ip:
public function getIp(){
foreach (array('HTTP_CLIENT_IP', 'HTTP_X_FORWARDED_FOR', 'HTTP_X_FORWARDED', 'HTTP_X_CLUSTER_CLIENT_IP', 'HTTP_FORWARDED_FOR', 'HTTP_FORWARDED', 'REMOTE_ADDR') as $key){
if (array_key_exists($key, $_SERVER) === true){
foreach (explode(',', $_SERVER[$key]) as $ip){
$ip = trim($ip); // just to be safe
if (filter_var($ip, FILTER_VALIDATE_IP, FILTER_FLAG_NO_PRIV_RANGE | FILTER_FLAG_NO_RES_RANGE) !== false){
return $ip;
}
}
}
}
}
На додаток до цього, я пропоную вам бути дуже обережними, використовуючи проміжне програмне забезпечення дросельної заслінки Laravel : воно використовує Laravel'sRequest::ip()
, так що всі ваші відвідувачі будуть ідентифіковані як один і той же користувач, і ви дуже швидко досягнете межі дроселя. Я пережив це наживо, і це спричинило великі проблеми.
Щоб виправити це:
Освітлити \ Http \ Request.php
public function ip()
{
//return $this->getClientIp(); //original method
return $this->getIp(); // the above method
}
Тепер ви також можете використовувати Request::ip()
, що повинно повернути реальний IP у виробництві.