Maison >développement back-end >tutoriel php >PHP限制IP访问 只允许指定IP地址访问

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

WBOY
WBOYoriginal
2016-07-25 08:54:421920parcourir
  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。



Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn