1. <rp id="c4hsd"></rp>
          1. <button id="c4hsd"><acronym id="c4hsd"><input id="c4hsd"></input></acronym></button>
          2. <tbody id="c4hsd"></tbody>

            <dd id="c4hsd"><pre id="c4hsd"></pre></dd>

              1. <th id="c4hsd"></th>
              2. <s id="c4hsd"><object id="c4hsd"></object></s>

                    [ 登錄 ] - [ 注冊 ] | 代碼示例DEMO | IP測試視頻 |

                    使用php獲取真實請求IP,區分代理IP

                    作者:數據無憂   時間:2020-09-18 13:24:53

                    使用php獲取IP的方法能找到很多。
                    function getIp(){
                    if (getenv("HTTP_CLIENT_IP") && strcasecmp(getenv("HTTP_CLIENT_IP"), "unknown"))
                    $ip = getenv("HTTP_CLIENT_IP");
                    else if (getenv("HTTP_X_FORWARDED_FOR") && strcasecmp(getenv("HTTP_X_FORWARDED_FOR"), "unknown"))
                    $ip = getenv("HTTP_X_FORWARDED_FOR");
                    else if (getenv("REMOTE_ADDR") && strcasecmp(getenv("REMOTE_ADDR"), "unknown"))
                    $ip = getenv("REMOTE_ADDR");
                    else if (isset($_SERVER['REMOTE_ADDR']) && $_SERVER['REMOTE_ADDR'] && strcasecmp($_SERVER['REMOTE_ADDR'], "unknown"))
                    $ip = $_SERVER['REMOTE_ADDR'];
                    else
                    $ip = "unknown";
                    return($ip);
                    }
                    對這段代碼進行解釋,這里用到了兩個函數,getenv()和strcasecmp(),前一個函數獲取得系統的環境變量,如果能取到值,則返回該值,不能則返回false.
                    $_SERVER是服務器超級全局變量數組,用$_SERVER['REMOTE_ADDR']同樣可以獲取到客戶端的IP地址.二者的區別在于,getenv不支持IIS的isapi方式運行的php.
                    strcasecmp(string1,string2)字符串函數的用法是把string1和string2進行比較,如果相等返回0,如果string1大于string2,返回大于0的數,小于則返回小于0的數.
                    函數先使用客戶IP,如果不成立嘗試用代理的方法,如果不行,再使用REMOTE_ADDR。

                    網友一回答
                    $_SERVER 打印這個 你什么都看到了

                    網友二回答
                    獲取客戶端ip其實不是個簡單的事兒,因為存在IP欺騙,和代理問題,所以獲取客戶端的IP的真實性會打折扣的,不能百分百準確。但是我們還是可以盡量寫一些比較完善的獲取客戶端真正ip方法。使用php獲取IP的方法能有很多,我簡單給個例子:

                    <?php
                    function getip() {
                    $unknown = 'unknown';
                    if(isset($_SERVER['HTTP_X_FORWARDED_FOR']) && $_SERVER['HTTP_X_FORWARDED_FOR'] && strcasecmp($_SERVER['HTTP_X_FORWARDED_FOR'], $unknown)){
                    $ip = $_SERVER['HTTP_X_FORWARDED_FOR'];
                    }elseif(isset($_SERVER['REMOTE_ADDR']) && $_SERVER['REMOTE_ADDR'] && strcasecmp($_SERVER['REMOTE_ADDR'], $unknown)) {
                    $ip = $_SERVER['REMOTE_ADDR'];
                    }
                    /**
                    * 處理多層代理的情況
                    * 或者使用正則方式:$ip = preg_match("/[\d\.]{7,15}/", $ip, $matches) ? $matches[0] : $unknown;
                    */
                    if (false !== strpos($ip, ',')) $ip = reset(explode(',', $ip));
                    return $ip;
                    }
                    ?>

                    1、沒有使用代理的情況
                    REMOTE_ADDR = 客戶端IP
                    HTTP_X_FORWARDED_FOR = 沒數值或不顯示

                    2、使用透明代理的情況
                    REMOTE_ADDR = 最后一個代理服務器 IP
                    HTTP_X_FORWARDED_FOR = 客戶端真實 IP (經過多個代理服務器時,這個值類似:221.5.252.160, 203.98.182.163, 203.129.72.215)
                    這類代理服務器還是將客戶端真實的IP發送給了訪問對象,無法達到隱藏真實身份的目的.

                    3、使用普通的匿名代理
                    REMOTE_ADDR = 最后一個代理服務器 IP
                    HTTP_X_FORWARDED_FOR = 代理服務器 IP (經過多個代理服務器時,這個值類似: 203.98.182.163, 203.98.182.163, 203.129.72.215)
                    這種情況下隱藏了客戶端的真實IP,但是向訪問對象透露了客戶端是使用代理服務器訪問它們的.

                    4、使用欺騙性代理服務器
                    REMOTE_ADDR = 代理服務器 IP
                    HTTP_X_FORWARDED_FOR = 隨機的 IP(經過多個代理服務器時,這個值類似:220.4.251.159, 203.98.182.163, 203.129.72.215)
                    這種情況下同樣透露了客戶端是使用了代理服務器,但編造了一個虛假的隨機IP(220.4.251.159)代替客戶端的真實IP來欺騙它.

                    5、使用高級匿名代理服務器
                    REMOTE_ADDR = 代理服務器 IP
                    HTTP_X_FORWARDED_FOR = 沒數值或不顯示,也可能是unknown




                    無憂代理IP(www.aooseo.com)原創文章,轉載請注明出處。

                    電話:4007-745-096
                    QQ:
                    周一至周日8:30-18:00 技術部電話熱線
                    久久夜色精品国产噜噜亚洲AV_老妇女性较大毛片_888亚洲欧美国产va在线播放_超碰人人透人人爽人人看