在php中中有自定義函數可以幫我人判斷IP地址,也有我們常用的正則函數來判斷IP地址,下面我分別來給各位同學總結了驗證IP地址的一些方法.
filter函數過濾ip地址的方法:
echo filter_var("127.0.0.1","FILTER_VALIDATE_INT"); //返回true or false
例子,判斷是否是合法IP,代碼如下:
- if(filter_var($ip, FILTER_VALIDATE_IP)) {
- // it's valid
- }
- else {
- // it's not valid
- }
判斷是否是合法的公共IPv4地址,192.168.1.1這類的私有IP地址將會排除在外,代碼如下:
- if(filter_var($ip, FILTER_VALIDATE_IP, FILTER_FLAG_IPV4 | FILTER_FLAG_NO_PRIV_RANGE)) {
- // it's valid
- }
- else {
- // it's not valid
- }
判斷是否是合法的IPv6地址,代碼如下:
- if(filter_var($ip, FILTER_VALIDATE_IP, FILTER_FLAG_NO_RES_RANGE)) {
- // it's valid
- }
- else {
- // it's not valid
- }
判斷是否是public IPv4 IP或者是合法的Public IPv6 IP地址,代碼如下:
- if(filter_var($ip, FILTER_VALIDATE_IP, FILTER_FLAG_NO_PRIV_RANGE | FILTER_FLAG_NO_RES_RANGE)) {
- // it's valid
- }
- else {
- // it's not valid
- }
簡單的正則:preg_match("/d{1,3}.d{1,3}.d{1,3}.d{1,3}/");// 此方法沒不精確,學最大為255.255.255.255 但這個只是驗證格式了,如999.999.999.999也可以通過驗證.
我們進入升級改進,代碼如下:
- functionis_ip($gonten){
- $ip=explode(”.”,$gonten);
- for($i=0;$i<count($ip);$i++)
- {
- if($ip[$i]>255){
- return(0);
- }
- }
- return ereg(”^[0-9]{1,3}.[0-9]{1,3}.[0-9]{1,3}.[0-9]{1,3}$”,$gonten);
- }
這樣就符合我們的要求了,再介紹一種用判斷ip地址,代碼如下:
- function matchip($q){
- preg_match('/((25[0-5])|(2[0-4]d)|(1dd)|([1-9]d)|d)(.((25[0-5])|(2[0-4]d)|(1dd)|([1-9]d)|d)){3}/', $q, $matches);
- return $matches[0];
- }
- $ipaddress = '201.103.2.2';
- $iperror ='262.3.6.6';
- $iptest = matchip( $ipaddress );
- //當我們給matchip 的值為$ipaddress輸出為201.103.2.2
- //當我們給matchip的函數值為$iperror時,輸出值為 62.3.6.6
- if( $iptest )
- {
- echo $iptest;
- }
- else
- {
- echo '提示:你輸的的ip地址有問題';
- }
新聞熱點
疑難解答