PHP若何限度拜访ip白名单?
一 、上代码
config.php
//ip白名单设置装备摆设 'ipWlist'=>[ 'ifFilter'=>true, //能否开启白名单性能 'wlist'=>[ '10.0.0.19', ], 'warea1'=>'10.8.0.0/16', //白名单网段1 'warea2'=>'10.12.0.0/16', //白名单网段1 ],
co妹妹onfunc.php
private function checkIp(){ $user_IP = ($_SERVER["HTTP_VIA"]) ? $_SERVER["HTTP_X_FORWARDED_FOR"] : $_SERVER["REMOTE_ADDR"]; $user_IP = ($user_IP) ? $user_IP : $_SERVER["REMOTE_ADDR"]; $ipC=config('appconf.ipWlist'); if(!$ipC['ifFilter']){ return true; } if(in_array($user_IP, $ipC['wlist'])){ return true; } if( ! $this->ip_in_network($user_IP, $ipC['warea1'])){ if( ! $this->ip_in_network($user_IP, $ipC['warea2'])){ return false; } } return true; } private function ip_in_network($ip, $network) { $ip = (double) (sprintf("%u", ip2long($ip))); $s = explode('/', $network); $network_start = (double) (sprintf("%u", ip2long($s[0]))); $network_len = pow(2, 32 - $s[1]); $network_end = $network_start + $network_len - 1; if ($ip >= $network_start && $ip <= $network_end) { return true; } return false; }
二 、阐明
2.1 猎取ip的形式
● $_SERVER["HTTP_VIA"] 有代办署理效劳器的时分,示意代办署理效劳器IP;
● $_SERVER["HTTP_X_FORWARDED_FOR"] 透过代办署理效劳器获得客户真个实在 IP 地点;
● $_SERVER["REMOTE_ADDR"] 在阅读以后页面用户的 IP 地点
普通来讲,开发者关于外部的效劳器架构比拟理解,简略粗犷的用REMOTE_ADDR便可,由于REMOTE_ADDR不成捏造,愈加平安,另外两个字段就没那末靠谱.
2.2 有的童鞋没有是用数组的config而是用define
能够用json_encode,序列化,eval()等形式来处理,以下
define("IPFILTER",1); define('IPWLISTJSON',json_encode(['127.0.0.1',])); // 营业中 $wlist = json_decode(IPWLISTJSON,1); define('IPWLIST',"return ['127.0.0.1',];"); // 营业中 $wlist=eval(IPWLIST) define('IPWLIST',serialize(['127.0.0.1',])); // 营业中 $wlist=unserialize(IPWLIST);
还能够用string非凡分隔符的explode方式等,这里就纷歧一举例了。
更多相干php常识,请拜访php教程!
以上就是PHP限度拜访ip白名单的办法详解的具体内容,更多请存眷资源魔其它相干文章!
标签: php php开发教程 php开发资料 php开发自学
版权声明:除非特别标注,否则均为本站原创文章,转载时请以链接形式注明文章出处。
抱歉,评论功能暂时关闭!