Heim  >  Artikel  >  Backend-Entwicklung  >  PHP限制IP访问 只允许指定IP地址访问

PHP限制IP访问 只允许指定IP地址访问

WBOY
WBOYOriginal
2016-07-25 08:54:421849Durchsuche
  1. /**
  2. * 检测访问的ip是否为规定的允许的ip
  3. * Enter description here ...
  4. */
  5. function check_ip(){
  6. $ALLOWED_IP=array('192.168.2.*','127.0.0.1','192.168.2.49');
  7. $IP=getIP();
  8. $check_ip_arr= explode('.',$IP);//要检测的ip拆分成数组
  9. #限制IP
  10. if(!in_array($IP,$ALLOWED_IP)) {
  11. foreach ($ALLOWED_IP as $val){
  12. if(strpos($val,'*')!==false){//发现有*号替代符
  13. $arr=array();//
  14. $arr=explode('.', $val);
  15. $bl=true;//用于记录循环检测中是否有匹配成功的
  16. for($i=0;$i if($arr[$i]!='*'){//不等于* 就要进来检测,如果为*符号替代符就不检查
  17. if($arr[$i]!=$check_ip_arr[$i]){
  18. $bl=false;
  19. break;//终止检查本个ip 继续检查下一个ip
  20. }
  21. }
  22. }//end for
  23. if($bl){//如果是true则找到有一个匹配成功的就返回
  24. return;
  25. die;
  26. }
  27. }
  28. }//end foreach
  29. header('HTTP/1.1 403 Forbidden');
  30. echo "Access forbidden";
  31. die;
  32. }
  33. }
  34. /**

  35. * 获得访问的IP
  36. * Enter description here ...
  37. */
  38. function getIP() {
  39. return isset($_SERVER["HTTP_X_FORWARDED_FOR"])?$_SERVER["HTTP_X_FORWARDED_FOR"]
  40. :(isset($_SERVER["HTTP_CLIENT_IP"])?$_SERVER["HTTP_CLIENT_IP"]
  41. :$_SERVER["REMOTE_ADDR"]);
  42. }
复制代码

调用方法: 在需要的文件中,加上调用 check_ip(); 即可达到IP访问限制的目的; 本函数提供只允许指定的IP访问文件,并提供IP中*号通配符 匹配多IP。



Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn