ホームページ > バックエンド開発 > PHPの問題 > PHPでさまざまなIPアクセスをシミュレートする方法

PHPでさまざまなIPアクセスをシミュレートする方法

藏色散人
リリース: 2023-03-17 12:52:01
オリジナル
2278 人が閲覧しました

PHP でさまざまな IP アクセスをシミュレートする方法: 1. IP およびソース アクセスを制限するページを設定します; 2. 通常のアクセスにはcurl を使用します; 3. 次のようなコードを使用して、curl を使用して IP およびソース アクセスをシミュレートします。 "curl_setopt($ch, CURLOPT_HTTPHEADER, array('CLIENT-IP: ip','X-FORWARDED-FOR: ip'));"。

PHPでさまざまなIPアクセスをシミュレートする方法

このチュートリアルの動作環境: Windows 7 システム、PHP バージョン 8.1、Dell G3 コンピューター。

php でさまざまな IP アクセスをシミュレートする方法

phpcurl を使用してアクセスの IP とソースをシミュレートする方法

制限事項 IP アドレスとソースのない Web サイトには、通常のアクセス方法ではアクセスできません。この記事では、PHPのcurlクラスを利用してIPとソースをシミュレートし、IPとソースを制限したWebサイトにアクセスする方法を紹介します。

1. IP とソースへのアクセスを制限するページを設定します

server.php

<?php
 
$client_ip = getip();
$referer = getreferer();
 
$allow_ip = &#39;192.168.1.100&#39;;
$allow_referer = &#39;https://www.jb51.net&#39;;
 
if($client_ip==$allow_ip && strpos($referer, $allow_referer)===0){
  echo &#39;allow access&#39;;
}else{
  echo &#39;deny access&#39;;
}
 
 
// 获取访问者ip
function getip(){
  if(!empty($_SERVER[&#39;HTTP_CLIENT_IP&#39;])){
    $cip = $_SERVER[&#39;HTTP_CLIENT_IP&#39;];
  }elseif(!empty($_SERVER[&#39;HTTP_X_FORWARDED_FOR&#39;])){
    $cip = $_SERVER[&#39;HTTP_X_FORWARDED_FOR&#39;];
  }elseif(!empty($_SERVER[&#39;REMOTE_ADDR&#39;])){
    $cip = $_SERVER[&#39;REMOTE_ADDR&#39;];
  }else{
    $cip = &#39;&#39;;
  }
  return $cip;
}
 
// 获取访问者来源
function getreferer(){
  if(isset($_SERVER[&#39;HTTP_REFERER&#39;])){
    return $_SERVER[&#39;HTTP_REFERER&#39;];
  }
  return &#39;&#39;;
}
 
?>
ログイン後にコピー

2. 通常のアクセスにはcurlを使用します

<?php
function doCurl($url, $data=array(), $header=array(), $timeout=30){
 
  $ch = curl_init();
  curl_setopt($ch, CURLOPT_URL, $url);
  curl_setopt($ch, CURLOPT_HTTPHEADER, $header);
  curl_setopt($ch, CURLOPT_POST, true);
  curl_setopt($ch, CURLOPT_POSTFIELDS, http_build_query($data));
  curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); 
  curl_setopt($ch, CURLOPT_TIMEOUT, $timeout);
 
  $response = curl_exec($ch);
 
  if($error=curl_error($ch)){
    die($error);
  }
 
  curl_close($ch);
 
  return $response;
 
}
 
// 调用
$url = &#39;http://www.example.com/server.php&#39;;
$response = doCurl($url);
 
echo $response;
?>
ログイン後にコピー

拒否に戻りますaccess

3.カールを使用して IP とソースにアクセスすることをシミュレートします

ソースをシミュレートする

curl_setopt($ch, CURLOPT_REFERER, &#39;来源&#39;);
ログイン後にコピー

ip をシミュレートする

curl_setopt($ch, CURLOPT_HTTPHEADER, array(&#39;CLIENT-IP: 模拟ip&#39;,&#39;X-FORWARDED-FOR: 模拟ip&#39;));
ログイン後にコピー

完全なコードは次のとおりです。 ##

<?php
function doCurl($url, $data=array(), $header=array(), $referer=&#39;&#39;, $timeout=30){
 
  $ch = curl_init();
  curl_setopt($ch, CURLOPT_URL, $url);
  curl_setopt($ch, CURLOPT_HTTPHEADER, $header);
  curl_setopt($ch, CURLOPT_POST, true);
  curl_setopt($ch, CURLOPT_POSTFIELDS, http_build_query($data));
  curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); 
  curl_setopt($ch, CURLOPT_TIMEOUT, $timeout);
 
  // 模拟来源
  curl_setopt($ch, CURLOPT_REFERER, $referer);
 
  $response = curl_exec($ch);
 
  if($error=curl_error($ch)){
    die($error);
  }
 
  curl_close($ch);
 
  return $response;
 
}
 
// 调用
$url = &#39;http://www.example.com/server.php&#39;;
$data = array();
 
// 设置IP
$header = array(
  &#39;CLIENT-IP: 192.168.1.100&#39;,
  &#39;X-FORWARDED-FOR: 192.168.1.100&#39;
);
 
// 设置来源
$referer = &#39;https://www.jb51.net/&#39;;
 
$response = doCurl($url, $data, $header, $referer, 5);
 
echo $response;
?>
ログイン後にコピー
アクセス許可を返す

推奨学習: 「

PHP ビデオ チュートリアル

以上がPHPでさまざまなIPアクセスをシミュレートする方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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