マルチ・パート・コンテント

HTTP のメッセージ・コンテントは、コンテント・タイプの異なるいくつかの部分から成る場合があります。 通常、ファイルのアップロードをリクエストする場合に、それが必要になります。 yii\httpclient\RequestaddContent()addFile() またはaddFileContent() メソッドを使って、マルチ・パートのコンテントを作成することが出来ます。 例えば、ウェブ・フォームを使うファイルのアップロードをエミュレートしたい場合は、次のようなコードを使用する事が出来ます。

use yii\httpclient\Client;

$client = new Client();
$response = $client->createRequest()
    ->setMethod('post')
    ->setUrl('http://domain.com/file/upload')
    ->addFile('file', '/path/to/source/file.jpg')
    ->send();

リクエストがマルチ・パートであるとマークされている場合であっても、yii\httpclient\Request::$data が指定されている場合は、 その値がコンテントの一部として自動的に送信されます。 例えば、次のようなフォームの送信をエミュレートしたいと仮定しましょう。

<form name="profile-form" method="post" action="http://domain.com/user/profile" enctype="multipart/form-data">
    <input type="text" name="username" value="">
    <input type="text" name="email" value="">
    <input type="file" name="avatar">
    <!-- ... -->
</form>

これは、次のようなコードを使って実行することが出来ます。

use yii\httpclient\Client;

$client = new Client();
$response = $client->createRequest()
    ->setMethod('post')
    ->setUrl('http://domain.com/user/profile')
    ->setData([
        'username' => 'johndoe',
        'email' => 'johndoe@domain.com',
    ])
    ->addFile('avatar', '/path/to/source/image.jpg')
    ->send();

同じ名前で複数のファイルを添付すると、最後のファイルでそれらが上書きされることに注意して下さい。 その場合、添付ファイルのための表形式入力のインデックスは、あなた自身が制御しなければなりません。例えば、

use yii\httpclient\Client;

$client = new Client();
$response = $client->createRequest()
    ->setMethod('POST')
    ->setUrl('http://domain.com/gallery')
    ->addFile('avatar[0]', '/path/to/source/image1.jpg')
    ->addFile('avatar[1]', '/path/to/source/image2.jpg')
    ...
    ->send();