サイトをリクエストするとき、http ヘッダーには IP 情報が含まれることがわかっています。この情報を偽造することで、さまざまな IP アクセス リクエストの効果を形成できます。
ヘッダー CLIENT-IP と X-FORWARDED-FOR を偽造したい IP に設定すると、サーバーは指定した IP を取得します。
X-Forwarded-For は拡張ヘッダーです。 HTTP/1.1 (RFC 2616) プロトコルでは定義されていません。HTTP リクエスターの実際の IP を表すために、キャッシング プロキシ ソフトウェアである Squid によって最初に導入されました。現在では事実上の標準となり、主要な HTTP で使用されていますプロキシ、負荷分散などの転送サービスは広く使用されており、RFC 7239 (Forwarded HTTP Extension) 標準に書き込まれています。
(関連する学習ビデオの共有: php ビデオ チュートリアル)
通常の TCP/IP の二者間通信の場合、ソース IP を偽造することは不可能です。つまり、TCP/IP プロトコルではデータ パケットの送信元 IP を偽装することができますが、これにより送信したデータ パケットが返ってこないため、正常な通信ができなくなります。これは、私たちが相手に手紙を書くとき、差出人の住所を間違えて、受信者が封筒の差出人の住所に従って返信すると、元の差出人は返信を受け取ることができないのと同じです。
SYN フラッドなどの一部の DDoS 攻撃は、TCP/ip のこの欠陥を利用して攻撃を実行します。
php によるランダム IP アクセスの構築例:
<?php function curl($url,$ifpost = 0, $datafields = '', $cookiefile = '', $v = false){ $ip_long = array( array('607649792', '608174079'), //36.56.0.0-36.63.255.255 array('1038614528', '1039007743'), //61.232.0.0-61.237.255.255 array('1783627776', '1784676351'), //106.80.0.0-106.95.255.255 array('2035023872', '2035154943'), //121.76.0.0-121.77.255.255 array('2078801920', '2079064063'), //123.232.0.0-123.235.255.255 array('-1950089216', '-1948778497'), //139.196.0.0-139.215.255.255 array('-1425539072', '-1425014785'), //171.8.0.0-171.15.255.255 array('-1236271104', '-1235419137'), //182.80.0.0-182.92.255.255 array('-770113536', '-768606209'), //210.25.0.0-210.47.255.255 array('-569376768', '-564133889'), //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)",'CLIENT-IP:'.$ip,'X-FORWARDED-FOR:'.$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 チュートリアル
以上がPHPでランダムIPアクセスを構築する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。