프록시 뒤에 실제 방문자 IP 가져오기
방문자가 프록시를 사용하는 경우 표준 PHP 방법 $_SERVER['REMOTE_ADDR']는 그렇지 않을 수 있습니다. 실제 방문자 IP 주소를 제공합니다. 이 문제를 해결하려면 다음 PHP 코드를 활용하는 것이 좋습니다.
<code class="php">function getUserIP() { // Handle CloudFlare network if (isset($_SERVER["HTTP_CF_CONNECTING_IP"])) { $_SERVER['REMOTE_ADDR'] = $_SERVER["HTTP_CF_CONNECTING_IP"]; $_SERVER['HTTP_CLIENT_IP'] = $_SERVER["HTTP_CF_CONNECTING_IP"]; } $client = @$_SERVER['HTTP_CLIENT_IP']; $forward = @$_SERVER['HTTP_X_FORWARDED_FOR']; $remote = $_SERVER['REMOTE_ADDR']; if(filter_var($client, FILTER_VALIDATE_IP)) { $ip = $client; } elseif(filter_var($forward, FILTER_VALIDATE_IP)) { $ip = $forward; } else { $ip = $remote; } return $ip; } $user_ip = getUserIP(); echo $user_ip; // Output real visitor IP address</code>
이 코드는 CloudFlare 네트워크를 확인하고 이에 따라 IP 주소를 조정합니다. 그런 다음 HTTP_CLIENT_IP, HTTP_X_FORWARDED_FOR 및 REMOTE_ADDR을 순서대로 검사하여 유효한 형식의 IP에 우선순위를 둡니다. 이 코드를 구현하면 프록시 뒤에 있는 경우에도 실제 방문자 IP 주소를 얻을 수 있습니다.
위 내용은 프록시 뒤에 있는 실제 방문자 IP 주소를 얻는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!