私はguzzleのset proxyに問題があります。curlですべてが完璧に機能しているのに空白ページが表示されました。 guzzleとcurlで使用したコードは以下のとおりです。このコードの何が問題になっていますか:Guzzle:
use GuzzleHttp\Client;
use GuzzleHttp\Exception\RequestException;
require_once "vendor/autoload.php";
try {
$client = new Client();
$request = new \GuzzleHttp\Psr7\Request('GET', 'http://httpbin.org');
$response = $client->send($request, [
'timeout' => 30,
'curl' => [
'CURLOPT_PROXY' => '*.*.*.*',
'CURLOPT_PROXYPORT' => *,
'CURLOPT_PROXYUSERPWD' => '*:*',
],
]);
echo '</pre>';
echo($response->getBody());
exit;
} catch (RequestException $e) {
echo $e->getRequest();
if ($e->hasResponse()) {
echo $e->getResponse();
}
}
そしてCURLのコード:
$url = 'http://httpbin.org';
$ch = curl_init($url);
curl_setopt($ch,CURLOPT_USERAGENT,'Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.8.1.13) Gecko/20080311 Firefox/2.0.0.13');
curl_setopt($ch, CURLOPT_PROXY, '*.*.*.*');
curl_setopt($ch, CURLOPT_PROXYPORT, *);
curl_setopt($ch, CURLOPT_PROXYUSERPWD, '*:*');
curl_setopt($ch, CURLOPT_HEADER, false);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_FOLLOWLOCATION, false);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
$page = curl_exec($ch);
echo $page;
ありがとう。
Guzzle 6。
Guzzle docs 単一のリクエストに対するプロキシの設定に関する情報を提供します
$client->request('GET', '/', ['proxy' => 'tcp://localhost:8125']);
ただし、クライアントを初期化するときにすべてのリクエストに設定できます
$client = new Client([
'base_uri' => 'http://doma.in/',
'timeout' => 10.0,
'cookie' => true,
'proxy' => 'tcp://12.34.56.78:3128',
]);
UPD。理由はわかりませんが、奇妙な行動に直面しています。 guzzleバージョン6.2.2を備えた1台のサーバーは、上記のようにconfigでうまく機能し、同じバージョンを備えたもう1台のサーバーは400 Bad Request
プロキシからのHTTPエラー。これは別の構成構造で解決されます( docs for guzzle にあります)
$client = new Client([
'base_uri' => 'http://doma.in/',
'timeout' => 10.0,
'cookie' => true,
'request.options' => [
'proxy' => 'tcp://12.34.56.78:3128',
],
]);
Psr-7の手順は異なる場合がありますが、クライアントをインスタンス化する標準的な方法を使用している場合は、
path\to\project\vendor\guzzlehttp\guzzle\src\Client.php、lines 164-17 には、現在のマシンでHTTP_PROXYおよびHTTPS_PROXYが設定されているかどうかを確認するために環境変数を読み取るコードが含まれています。はいの場合、Guzzleはそれらの値を使用します。
さらに、職場のプロキシがhttpプロトコルを介してhttpsとhttpの両方のリクエストを処理しているように見えるため、HTTPS_PROXY = http:// ip:port (httpsではない)を設定する必要がありました。
この構成の利点は、ソースコードでプロキシ設定を変更する必要がないことです。
現在同じ問題があり、私がする必要があるのは、文字列ではなく、カール配列のキーを定数として使用することだけでした。
$response = $client->send($request, [
'timeout' => 30,
'curl' => [
CURLOPT_PROXY => '*.*.*.*',
CURLOPT_PROXYPORT => *,
CURLOPT_PROXYUSERPWD => '*:*',
],
]);
CURL options Keysを参照してください。これらはもはや文字列ではありません。
$response = \Drupal::httpClient()->post($settings['base_url'] . 'api/search/', [
'verify' => true,
'body' => $post_data,
'headers' => [
'Content-type' => 'application/json',
],
'curl' => [
CURLOPT_SSLVERSION => CURL_SSLVERSION_TLSv1_2,
CURLOPT_PROXY => 'proxyip:58080'],
]
)->getBody()->getContents();
Guzzleでプロキシ/ httpsを設定し、SSLで完璧に動作します。
Guzzle6の場合、プロキシを設定するためのミドルウェアを実装するのが最善の方法だと思います。
Guzzle6ドキュメントから:
以下のようにプロキシを設定できます。
use Psr\Http\Message\RequestInterface;
use GuzzleHttp\HandlerStack;
use GuzzleHttp\Handler\CurlHandler;
use GuzzleHttp\Client;
use GuzzleHttp\Middleware;
use Util\Api;
function add_proxy_callback($proxy_callback) {
return function (callable $handler) use ($proxy_callback) {
return function (RequestInterface $request,$options) use ($handler,$proxy_callback) {
$ip = $proxy_callback();
$options['proxy'] = $ip;
return $handler($request,$options);
};
};
}
$stack = new HandlerStack();
$stack->setHandler(new CurlHandler());
$stack->Push(add_proxy_callback(function() {
return Api::getIp(); //function return a ip
}));
$client = new Client(['handler'=>$stack]);
$response = $client->request('GET','http://httpbin.org/ip');
var_dump((string)$response->getBody());
プロキシの場合、ユーザー名とパスワードを持っている場合は、次を使用できます。
$client = new GuzzleHttp\Client();
$res = $client->request("POST", "https://endpoint.com", [
"proxy" => "http://username:[email protected]:10",
]);
これはphpのguzzleで動作しました。