web-dev-qa-db-ja.com

cURL IPアドレス

サーバーのIPアドレスではなく、ユーザーのIPアドレスを使用してcurl要求を送信する必要があります。私は運なしでこれを試しました:

curl_setopt( $ch, CURLOPT_INTERFACE, $ip );

何か案は?

ありがとう!

22
Flatline

OK、したがって、カールリクエストのIPアドレスを安全にスプーフィングする方法はありませんが、安全でない方法を見つけました。リクエストを受信するサーバースクリプトに依存しますが、リクエストを行っていたAPIをtrickすために機能しましたに:

curl_setopt( $ch, CURLOPT_HTTPHEADER, array("REMOTE_ADDR: $ip", "HTTP_X_FORWARDED_FOR: $ip"));

これは常に機能するとは限りませんが、この場合は機能しました。

助けてくれてありがとう!

39
Flatline

それは私にはカールで動作しないので、私はそれを回避する方法を見つけました、私はこれを行う必要があり、IPがあなたのサーバーに割り当てられている限り、

echo http_socket::download('http://something.com', '55.55.44.33');

final class http_socket
{
    static public function download($url, $bind_ip = false)
    { 
        $components = parse_url($url);
        if(!isset($components['query'])) $components['query'] = false;

        if(!$bind_ip) 
        {
            $bind_ip = $_SERVER['SERVER_ADDR'];
        }

        $header = array();
        $header[] = 'GET ' . $components['path'] . ($components['query'] ?  '?' . $components['query'] : '');
        $header[] = 'Host: ' . $components['Host'];
        $header[] = 'User-Agent: Mozilla/5.0 (X11; U; Linux i686; en-US; rv:1.9.1.7) Gecko/20100106 Ubuntu/9.10 (karmic) Firefox/3.5.7';
        $header[] = 'Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8';
        $header[] = 'Accept-Language: en-us,en;q=0.5';
        $header[] = 'Accept-Encoding: gzip,deflate';
        $header[] = 'Accept-Charset: ISO-8859-1,utf-8;q=0.7,*;q=0.7';
        $header[] = 'Keep-Alive: 300';
        $header[] = 'Connection: keep-alive';
        $header = implode("\n", $header) . "\n\n";
        $packet = $header;

        //----------------------------------------------------------------------
        // Connect to server
        //----------------------------------------------------------------------
        $socket = socket_create(AF_INET, SOCK_STREAM, SOL_TCP);
        socket_bind($socket, $bind_ip);
        socket_connect($socket, $components['Host'], 80);

        //----------------------------------------------------------------------
        // Send First Packet to Server
        //----------------------------------------------------------------------
        socket_write($socket, $packet);
        //----------------------------------------------------------------------
        // Receive First Packet to Server
        //----------------------------------------------------------------------
        $html = '';
        while(1) {
            socket_recv($socket, $packet, 4096, MSG_WAITALL);
            if(empty($packet)) break;
            $html .= $packet;
        }
        socket_close($socket);

        return $html;
    }
}
11
Gorilla3D

IPアドレスのなりすましは、cURLでできることではありません。これは、生のソケット接続の操作を必要とする低レベルの操作です。

8
Richard Simões

私にとって上手な解決策はありません。ただし、プロキシを介したリクエストの作成は非常にうまく機能します。

$url = 'http://dynupdate.no-ip.com/ip.php';
$proxy = '127.0.0.1:8888'; //put your proxy here
//$proxyauth = 'user:password';

$ch = curl_init();
curl_setopt($ch, CURLOPT_URL,$url);
curl_setopt($ch, CURLOPT_PROXY, $proxy);
//curl_setopt($ch, CURLOPT_PROXYUSERPWD, $proxyauth);
curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
$result = curl_exec($ch);
curl_close($ch);

echo $result;
7
Sergiu Sandrean

これは、サーバーのIPアドレスをそこに配置することになっているためです。

Curlを使用して、偽の送信元アドレスを持つIPパケットを偽造することはできません。

3
Zed

動作する可能性のあるphpコードの行を次に示します。 「X-Forwarded-For」ヘッダーを設定するには、他の方法を使用できます。

$httpClient = new Zend_Http_Client($reqUrl);
$httpClient->setHeaders("X-Forwarded-For","127.0.0.1");  //---this sets the desired ip address
3
Sameer Girolkar

REMOTE_ADDR:majbase HTTP_X_FORWARDED_FORのようなタグをヘッダーに追加します。「HTTP_X_REAL_IP:xxx.xxx.xxx.xx」のようなcodix

「HTTP_X_REAL_IP:xxx.xxx.xxx.xx」のようなHTTP_X_FORWARDED_FORおよびREMOTE_ADDRに加えて、HTTP_X_REAL_IPヘッダーを使用します

0
iamnamrud