ホームページ  >  記事  >  バックエンド開発  >  PHPはランダムIPアクセスを設定します

PHPはランダムIPアクセスを設定します

angryTom
angryTom転載
2019-10-15 14:29:023326ブラウズ

PHPはランダムIPアクセスを設定します

サイトをリクエストすると、http ヘッダーに IP 情報が含まれます。この情報を偽造することで、さまざまな IP アクセス リクエストの効果を形成できます。

ヘッダー ヘッダー CLIENT-IP および X-FORWARDED-FOR は、偽造する IP に設定され、サーバーは指定した IP を取得します。 .

推奨学習: PHP ビデオ チュートリアル

##X-Forwarded-For は拡張ヘッダーです。 HTTP/1.1 (RFC 2616) プロトコルでは定義されていません。HTTP リクエスターの実際の IP を表すために、キャッシング プロキシ ソフトウェアである Squid によって最初に導入されました。現在では事実上の標準となり、主要な HTTP で使用されていますプロキシ、ロード バランシングなどの転送サービスは広く使用されており、RFC 7239 (Forwarded HTTP Extension) 標準に書き込まれています。

通常の TCP/IP の 2 者間通信の場合、ソース IP は偽造できません。つまり、TCP/IPプロトコルではデータパケットの送信元IPを偽装できると言われていますが、これでは送信したデータパケットが戻ってこなくなり、正常な通信ができなくなります。これは、私たちが相手に手紙を書くとき、差出人の住所を間違えて、受信者が封筒の差出人の住所に従って返信すると、元の差出人は返信を受け取ることができないのと同じです。

SYN フラッドなどの一部の DDoS 攻撃は、TCP/ip のこの欠陥を利用して攻撃を実行します。

以下では、PHP がランダム アクセスを構築する方法について説明します。

<?php
function curl($url,$ifpost = 0, $datafields = &#39;&#39;, $cookiefile = &#39;&#39;, $v = false){
$ip_long = array(
            array(&#39;607649792&#39;, &#39;608174079&#39;), //36.56.0.0-36.63.255.255
            array(&#39;1038614528&#39;, &#39;1039007743&#39;), //61.232.0.0-61.237.255.255
            array(&#39;1783627776&#39;, &#39;1784676351&#39;), //106.80.0.0-106.95.255.255
            array(&#39;2035023872&#39;, &#39;2035154943&#39;), //121.76.0.0-121.77.255.255
            array(&#39;2078801920&#39;, &#39;2079064063&#39;), //123.232.0.0-123.235.255.255
            array(&#39;-1950089216&#39;, &#39;-1948778497&#39;), //139.196.0.0-139.215.255.255
            array(&#39;-1425539072&#39;, &#39;-1425014785&#39;), //171.8.0.0-171.15.255.255
            array(&#39;-1236271104&#39;, &#39;-1235419137&#39;), //182.80.0.0-182.92.255.255
            array(&#39;-770113536&#39;, &#39;-768606209&#39;), //210.25.0.0-210.47.255.255
            array(&#39;-569376768&#39;, &#39;-564133889&#39;), //222.16.0.0-222.95.255.255
    );
    $rand_key = mt_rand(0, 9);
    $ip= long2ip(mt_rand($ip_long[$rand_key][0], $ip_long[$rand_key][1]));
$header = array("Connection: Keep-Alive","Accept: text/html, application/xhtml+xml, */*", "Pragma: no-cache", "Accept-Language: zh-Hans-CN,zh-Hans;q=0.8,en-US;q=0.5,en;q=0.3","User-Agent: Mozilla/5.0 (compatible; MSIE 10.0; Windows NT 6.2; WOW64; Trident/6.0)",&#39;CLIENT-IP:&#39;.$ip,&#39;X-FORWARDED-FOR:&#39;.$ip); 
$ch = curl_init(); 
curl_setopt($ch, CURLOPT_URL, $url); 
curl_setopt($ch, CURLOPT_HEADER, $v); 
curl_setopt($ch, CURLOPT_HTTPHEADER, $header); 
$ifpost && curl_setopt($ch, CURLOPT_POST, $ifpost); 
$ifpost && curl_setopt($ch, CURLOPT_POSTFIELDS, $datafields); 
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); 
curl_setopt($ch, CURLOPT_FOLLOWLOCATION, true); 
$cookiefile && curl_setopt($ch, CURLOPT_COOKIEFILE, $cookiefile); 
$cookiefile && curl_setopt($ch, CURLOPT_COOKIEJAR, $cookiefile); 
curl_setopt($ch,CURLOPT_TIMEOUT,30); //允许执行的最长秒数
$ok = curl_exec($ch); 
curl_close($ch); 
unset($ch);
return $ok;
}
print_r(curl("URL"));
?>

以上がPHPはランダムIPアクセスを設定しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事はwww.80shihua.comで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。