>  기사  >  백엔드 개발  >  프록시 뒤에 있는 실제 방문자 IP 주소를 얻는 방법은 무엇입니까?

프록시 뒤에 있는 실제 방문자 IP 주소를 얻는 방법은 무엇입니까?

Barbara Streisand
Barbara Streisand원래의
2024-11-06 17:54:02264검색

How to Get the Real Visitor IP Address Behind Proxies?

프록시 뒤에 실제 방문자 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.