色尼玛亚洲综合影院,亚洲3atv精品一区二区三区,麻豆freexxxx性91精品,欧美在线91

web站點(diǎn)獲取用戶(hù)IP的安全方法 HTTP_X_FORWARDED_FOR檢驗(yàn)

安全過(guò)濾后的getIP函數(shù)

復(fù)制代碼 代碼如下:
  function getIP() {
 $realip = ''; //設(shè)置默認(rèn)值
 if (isset($_SERVER['HTTP_X_FORWARDED_FOR'])) {
  $realip = $_SERVER['HTTP_X_FORWARDED_FOR'];
 } elseif (isset($_SERVER['HTTP_CLIENT_IP'])) {
  $realip = $_SERVER['HTTP_CLIENT_IP'];
 } else {
  $realip = $_SERVER['REMOTE_ADDR'];
 }

 preg_match('/^((?:/d{1,3}/.){3}/d{1,3})/',$realip,$match);
 return $match?$match[0]:false;
}

以上函數(shù),增加了IP判斷,只會(huì)讀取以Ip格式數(shù)據(jù)開(kāi)頭,并且第一個(gè)滿(mǎn)足IP格式值。如果沒(méi)有返回false。 這樣就可以讀取到滿(mǎn)足格式的IP,驗(yàn)證了數(shù)據(jù)的IP格式。

如果我讀取互聯(lián)網(wǎng)的IP,用戶(hù)傳入局域網(wǎng)的IP,我應(yīng)該直接過(guò)濾掉

我們?cè)谝恍┚W(wǎng)站上面,經(jīng)常可以看到提示,非法的IP地址,其實(shí)一部分是IP地址格式錯(cuò)誤,一部分可能是讀取到IP地址,不滿(mǎn)足互聯(lián)網(wǎng)上面允許IP格式。 以下這個(gè)函數(shù),是通過(guò)IANA站點(diǎn)規(guī)范,封裝了個(gè)函數(shù)。 通過(guò)輸入IP地址,能夠準(zhǔn)確知道,該IP是不是可以在互聯(lián)網(wǎng)應(yīng)用

復(fù)制代碼 代碼如下:
//互聯(lián)網(wǎng)允許使用IP地址
function ipType2($ip) {
 $iplist = explode(".", $ip);

 if ($iplist[0] >= 224 && $iplist[0] <= 239)
  return '多播';
 if ($iplist[0] >= 240 && $iplist[0] <= 255)
  return '保留';

 if (preg_match('/^198/.51/.100/', $ip))
  return 'TEST-NET-2,文檔和示例';
 if (preg_match('/^203/.0/.113/', $ip))
  return 'TEST-NET-3,文檔和示例';

 if (preg_match('/^192/.(18|19)/./', $ip))
  return '網(wǎng)絡(luò)基準(zhǔn)測(cè)試';

 if (preg_match('/^192/.168/', $ip))
  return '專(zhuān)用網(wǎng)絡(luò)[內(nèi)部網(wǎng)]';

 if (preg_match('/^192/.88/.99/', $ip))
  return 'ipv6to4中繼';
 if (preg_match('/^192/.0/.2/./', $ip))
  return 'TEST-NET-1,文檔和示例';
 if (preg_match('/^192/.0/.0/./', $ip))
  return '保留(IANA)';
 if (preg_match('/^192/.0/.0/./', $ip))
  return '保留(IANA)';

 if ($iplist[0] == 172 && $iplist[1] <= 31 && $iplist[1] >= 16)
  return '專(zhuān)用網(wǎng)絡(luò)[內(nèi)部網(wǎng)]';

 if ($iplist[0] == 169 && $iplist[1] == 254)
  return '鏈路本地';
 if ($iplist[0] == 127)
  return '環(huán)回地址';
 if ($iplist[0] == 10)
  return '專(zhuān)用網(wǎng)絡(luò)[內(nèi)部網(wǎng)]';
 if ($iplist[0] == 0)
  return '本網(wǎng)絡(luò)(僅作為源地址時(shí)合法)';

 return 'InterNET網(wǎng)地址';
}

當(dāng)你輸入IP地址,它返回是“'InterNET網(wǎng)地址' ,那么這個(gè)IP地址不光格式正確,而且是互聯(lián)網(wǎng)上面合法的IP地址。 這個(gè)函數(shù)很復(fù)雜,其實(shí)就是排除很多非互聯(lián)網(wǎng)使用IP地址。 我們常見(jiàn)的192,127,10開(kāi)頭地址估計(jì)都很熟悉了。 但實(shí)際上,很多IP地址是保留的,或者留作它用。 不能作為互聯(lián)網(wǎng) IP使用。 有了以上兩個(gè)函數(shù),我們不光可以讀到正確格式IP地址,還能夠保證讀到是互聯(lián)網(wǎng)上面IP地址。 以上是工作中常使用的函數(shù),歡迎朋友們交流!

作者:chengmo  QQ:8292669

php技術(shù)web站點(diǎn)獲取用戶(hù)IP的安全方法 HTTP_X_FORWARDED_FOR檢驗(yàn),轉(zhuǎn)載需保留來(lái)源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 双桥区| 芷江| 车险| 定日县| 马鞍山市| 岚皋县| 和平区| 河曲县| 堆龙德庆县| 南京市| 桃源县| 辰溪县| 宁乡县| 陈巴尔虎旗| 宜君县| 汾阳市| 雅江县| 永春县| 华池县| 台前县| 武陟县| 田林县| 外汇| 阜康市| 庆阳市| 隆安县| 象州县| 卢氏县| 龙井市| 山阴县| 平凉市| 府谷县| 黄冈市| 金坛市| 江安县| 四子王旗| 嘉黎县| 南汇区| 肥城市| 平利县| 晋州市|