この記事では主に、PHP での IP とソースへのアクセスをシミュレートするためにcurl を使用する方法を紹介します。興味のある方はぜひ参考にしてください。
IP アドレスとソースが制限されている Web サイトには、通常のアクセス方法ではアクセスできません。この記事では、PHPのcurlクラスを使ってIPとソースをシミュレートし、IPとソースを制限したWebサイトにアクセスする方法を紹介します。
1. ページ制限IPとソースアクセスを設定します
server.php
<?php $client_ip = getip(); $referer = getreferer(); $allow_ip = '192.168.1.100'; $allow_referer = 'http://www.jb51.net'; if($client_ip==$allow_ip && strpos($referer, $allow_referer)===0){ echo 'allow access'; }else{ echo 'deny access'; } // 获取访问者ip function getip(){ if(!empty($_SERVER['HTTP_CLIENT_IP'])){ $cip = $_SERVER['HTTP_CLIENT_IP']; }elseif(!empty($_SERVER['HTTP_X_FORWARDED_FOR'])){ $cip = $_SERVER['HTTP_X_FORWARDED_FOR']; }elseif(!empty($_SERVER['REMOTE_ADDR'])){ $cip = $_SERVER['REMOTE_ADDR']; }else{ $cip = ''; } return $cip; } // 获取访问者来源 function getreferer(){ if(isset($_SERVER['HTTP_REFERER'])){ return $_SERVER['HTTP_REFERER']; } return ''; } ?>
2. 通常通りアクセスするにはcurlを使用します
りー
アクセスを拒否します
3.curlを使用してアクセスのIPとソースをシミュレートします
sourceをシミュレートします
curl_setopt($ch, CURLOPT_REFERER, 'source');simulateイプ
curl_setopt ($ch, CURLOPT_HTTPHEADER, array('CLIENT-IP: シミュレートされた ip','X-FORWARDED-FOR: シミュレートされた ip'));完全なコードは次のとおりです:
<?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 = 'http://www.example.com/server.php'; $response = doCurl($url); echo $response; ?>
アクセスを許可する
以上がこの記事の全内容です、皆様の学習のお役に立てれば幸いです。PHPUTF-8文字列のスキルを正しく解析するアプリケーション_phpの基礎
以上がPHP は、curl を使用して IP とアクセス元をシミュレートするメソッドを実装します。の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。