PHPで特定のIPへのアクセスを制限する方法

怪我咯
リリース: 2017-07-11 16:39:54
オリジナル
2861 人が閲覧しました

LAN 共有ファイルのアクセス許可を設定する過程で、共有ファイル管理

セキュリティ管理が必要になり、特定の IP アドレスによる LAN 共有ファイルへのアクセスや、特定のコンピュータによるサーバー共有ファイルへのアクセスを禁止する場合があります。この側面は、共有フォルダーに対するユーザーのアクセス権限を設定することで実現できます。たとえば、あるユーザーが共有フォルダーにアクセスすることを禁止できますが、共有ファイルにアクセスする権限を持つユーザーが他のユーザーに公開され、訪問者がそれを利用できる可能性があります。の他のアカウントも共有ファイルにアクセスできます。したがって、この場合は、次の方法で、指定したコンピューターが共有フォルダーにアクセスできないようにすることができます。

この記事では主に、PHP でのクライアント IP の取得、解析、トラバース、判断などの関連操作スキルを含む、PHP での IP アクセスを制限する方法を紹介します。必要な方は参考にしてください。この記事の例では、実装について説明します。 PHP IP アクセス方式の制限事項について説明します。参考のために皆さんと共有します。詳細は次のとおりです:

//获取客户端ip
if (getenv("HTTP_CLIENT_IP"))
  $ip = getenv("HTTP_CLIENT_IP"); 
else if(getenv("HTTP_X_FORWARDED_FOR"))
  $ip = getenv("HTTP_X_FORWARDED_FOR");
else if(getenv("REMOTE_ADDR"))
  $ip = getenv("REMOTE_ADDR");
else $ip = "Unknow";
$ALLOWED_IP=array('10.144.39.132');
//允许访问的ip
$check_ip_arr= explode('.',$ip);
//ip参数拆分成数组
if(!in_array($ip,$ALLOWED_IP)) {
  $bl=false;
  foreach ($ALLOWED_IP as $val){
    if(strpos($val,'*')!==false){
      //发现有*号替代符
      $arr=array();
      $arr=explode('.', $val);
      $bl=true;
      //用于记录循环检测中是否有匹配成功的
      for ($i=0;$i<4;$i++){
        if($arr[$i]!=&#39;*&#39;){
          //不等于* 就要进来检测,如果为*符号替代符就不检查
          if($arr[$i]!=$check_ip_arr[$i]){
            $bl=false;
            break;
            //终止检查本个ip 继续检查下一个ip
          }
        }
      }
      //end for
      if($bl){
        //如果是true则终止匹配
        break;
      }
    }
  }
  //end foreach
  if(!$bl){
    $return=array(
       &#39;status&#39;=>2,
       &#39;msg&#39;=>&#39;该IP无权限访问&#39;,
       &#39;data&#39;=>$ip
       );
    echo json_encode($return);
    exit();
  }
}
ログイン後にコピー

以上がPHPで特定のIPへのアクセスを制限する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート