Version: 5.3 (switch to 5.4b)
言語English
  • C#
  • JS

スクリプト言語

好きな言語を選択してください。選択した言語でスクリプトコードが表示されます。

UnityWebRequest.Post

フィードバック

ありがとうございます

この度はドキュメントの品質向上のためにご意見・ご要望をお寄せいただき、誠にありがとうございます。頂いた内容をドキュメントチームで確認し、必要に応じて修正を致します。

閉じる

送信に失敗しました

なんらかのエラーが発生したため送信が出来ませんでした。しばらく経ってから<a>もう一度送信</a>してください。ドキュメントの品質向上のために時間を割いて頂き誠にありがとうございます。

閉じる

キャンセル

マニュアルに切り替える
public static function Post(uri: string, postData: string): Experimental.Networking.UnityWebRequest;
public static Experimental.Networking.UnityWebRequest Post(string uri, string postData);

パラメーター

uri フォームデータが送信されるターゲット URI
postData ボディデータを作ります。送信前に WWWTranscoder.URLEncode で URLEncoded になります。

戻り値

UnityWebRequest UnityWebRequest は POST を介して uri にフォームデータを送信するように設定します。

説明

UnityWebRequest は HTTP POST を介してサーバーにフォームデータを送信する設定を作成します。

このメソッドは UnityWebRequest を作成し、url をストリングの引数 uri にセットし、methodPOST にセットします。 Content-Type ヘッダーはデフォルトでは application/x-www-form-urlencoded にセットされます。

Note: サーバーバックエンド多くの言語は application/x-www-form-urlencodedmultipart/form-data よりも他のエンコーディングにセットする Content-Type ヘッダーと一緒に POST リクエストを正しく処理しません。

このメソッドは DownloadHandlerBufferUnityWebRequest にアタッチします。これは利便性のためにほとんどのユーザーが特に REST API のケースでサーバーからの応答を確認するために DownloadHandler を使うことを予想しています。

PostData 内のデータは WWWTranscoder.URLEncode を介してエスケープされ、 System.Text.Encoding.UTF8 を介してバイトストリームにインタプリタされます。インタプリタ結果のバイトストリームを UploadHandlerRaw に格納し、アップロードのハンドラーは この UnityWebRequest にアタッチされます。

no example available in JavaScript
using UnityEngine;
using UnityEngine.Experimental.Networking;
using System.Collections;
 
class MyBehavior: public MonoBehaviour {
    void Start() {
        StartCoroutine(Upload());
    }
 
    IEnumerator Upload() {
        WWWForm form = new WWWForm();
        form.AddField("myField", "myData");
 
        using(UnityWebRequest www = UnityWebRequest.Post("http://www.my-server.com/myform", form)) {
            yield return www.Send();
     
            if(www.isError) {
                Debug.Log(www.error);
            }
            else {
                Debug.Log("Form upload complete!");
            }
        }
    }
}

public static function Post(uri: string, formData: WWWForm): Experimental.Networking.UnityWebRequest;
public static Experimental.Networking.UnityWebRequest Post(string uri, WWWForm formData);

パラメーター

uri フォームデータが送信されるターゲット URI
formData 書式設定とリモートサーバーへの送信のためフィールドをフォームします。またはファイルを WWWForm オブジェクトでカプセル化します。

戻り値

UnityWebRequest UnityWebRequest は POST を介して uri にフォームデータを送信するように設定します。

説明

UnityWebRequest は HTTP POST を介してサーバーにフォームデータを送信する設定を作成します。

このメソッドは UnityWebRequest を作成し、ストリングの引数 uriurl をセットし、methodPOST にセットします。 Content-Type ヘッダーは formData パラメーターからコピーされます。

このメソッドは DownloadHandlerBufferUnityWebRequest にアタッチします。これは利便性のためにほとんどのユーザーが特に REST API のケースでサーバーからの応答を確認するために DownloadHandler を使うことを予想しています。

FormData オブジェクトはそのコンテンツに応じて適切にフォーマットされたバイトストリームを生成します。結果としてバイトストリームを UploadHandlerRaw に格納し、アップロードハンドラーはこの UnityWebRequest にアタッチします。

no example available in JavaScript
using UnityEngine;
using UnityEngine.Experimental.Networking;
using System.Collections;
 
class MyBehavior: public MonoBehaviour {
    void Start() {
        StartCoroutine(Upload());
    }
 
    IEnumerator Upload() {
        WWWForm form = new WWWForm();
        form.AddField("myField", "myData");
 
        UnityWebRequest www = UnityWebRequest.Post("http://www.my-server.com/myform", form);
        yield return www.Send();
 
        if(www.isError) {
            Debug.Log(www.error);
        }
        else {
            Debug.Log("Form upload complete!");
        }
    }
}

public static function Post(uri: string, multipartFormSections: List<IMultipartFormSection>): Experimental.Networking.UnityWebRequest;
public static Experimental.Networking.UnityWebRequest Post(string uri, List<IMultipartFormSection> multipartFormSections);
public static function Post(uri: string, multipartFormSections: List<IMultipartFormSection>, boundary: byte[]): Experimental.Networking.UnityWebRequest;
public static Experimental.Networking.UnityWebRequest Post(string uri, List<IMultipartFormSection> multipartFormSections, byte[] boundary);

パラメーター

uri フォームデータが送信されるターゲット URI
multipartFormSections フォームフィールドのリストまたはフォーマットされたリモートサーバーに送信するファイル
boundary マルチパートフォームのフォームフィールドを分離するとき使用されるユニークなバウンダリ(境界)文字列です。供給されていない場合、バウンダリは生成されます。

戻り値

UnityWebRequest UnityWebRequest は POST を介して uri にフォームデータを送信するように設定します。

説明

UnityWebRequest は HTTP POST を介してサーバーにフォームデータを送信する設定を作成します。

このメソッドは UnityWebRequest を作成し、url をストリングの引数 uri にセットし、methodPOST にセットします。 Content-Type ヘッダーは適切なバウンダリ仕様で multipart/form-data にセットされます。

カスタム boundary バイト配列を指定する場合はバイトシーケンスが一意であること保証する必要があり、フォームデータのボディのどこであろうとでてこない必要があることに注意してください。マルチパートフォームとフォームバウンダリーの詳細については RFC 2388 を参照してください。

このメソッドは DownloadHandlerBufferUnityWebRequest にアタッチします。これは利便性のためにほとんどのユーザーが特に REST API のケースでサーバーからの応答を確認するために DownloadHandler を使うことを予想しています。

multipartFormSectionsIMultipartFormSection オブジェクトリストは有効なマルチパートフォームボディにフォーマットされます。各オブジェクトは個別のフォームセクションとしてインタプリタされます。このマルチパートフォームボディのフォーマット設定から生じるバイトストリームは UploadHandlerRaw で保存され、この UnityWebRequest にアタッチされます。

IMultipartFormSection の使用

フォームデータ指定をより細かく制御する方法を提供するために UnityWebRequest システムには (ユーザーが実装可能な) IMultipartFormSection インターフェイスが含まれています。標準的なアプリケーションのために Unity にデフォルトでデータとファイルセクションの実装が用意されています。

参照: MultipartFormDataSection 、[[MultipartFormFileSection]

IMultipartFormSection リストオブジェクトはこのメソッドを提供できます。リストのメンバーは RFC 2388 で定義されているマルチパート形式にフォーマットされます。

マルチパートフォームはフィールド間の分離を定義する任意のバウンダリーストリングが必要となります。バウンダリーストリングはリクエストにおいてどのフォームフィールドのボディ内のどこにも存在しないと保証しなければなりません。バウンダリーを指定しない場合、Unity は バウンダリーを生成します。生成されたバウンダリーは 40 のランダムな Printable バイトです。フォームフィールドデータと正確な一致は必要とされていません。ただし、アプリケーションがカスタムのバウンダリーストリングを指定する必要がある場合、行うことがあります。

指定したバウンダリーがあれば、バイト配列から UTF-8 文字列に自動的に変換されます。

no example available in JavaScript
using UnityEngine;
using UnityEngine.Experimental.Networking;
using System.Collections;
 
class MyBehavior: public MonoBehaviour {
    void Start() {
        StartCoroutine(Upload());
    }
 
    IEnumerator Upload() {
        WWWForm form = new WWWForm();
        form.AddField("myField", "myData");
 
        UnityWebRequest www = UnityWebRequest.Post("http://www.my-server.com/myform", form);
        yield return www.Send();
 
        if(www.isError) {
            Debug.Log(www.error);
        }
        else {
            Debug.Log("Form upload complete!");
        }
    }
}

public static function Post(uri: string, formFields: Dictionary<string,string>): Experimental.Networking.UnityWebRequest;
public static Experimental.Networking.UnityWebRequest Post(string uri, Dictionary<string,string> formFields);

パラメーター

uri フォームデータが送信されるターゲット URI
formFields フォームフィールドのキーと値を示すストリング。自動的に URL エンコードされたフォームボディにフォーマットされます。

戻り値

UnityWebRequest UnityWebRequest は POST を介して uri にフォームデータを送信するように設定します。

説明

UnityWebRequest は HTTP POST を介してサーバーにフォームデータを送信する設定を作成します。

このメソッドは UnityWebRequest を作成し、ストリングの引数 uriurl をセットして /method/を POST にセットします。 Content-Type ヘッダーは application/x-www-form-urlencoded にセットされます。

FormFields でストリングのディクショナリは、フィールド Id はディクショナリキーとして、ディクショナリの値はフィールド値としてフォームフィールドのリストはインタプリタされます。キーと値の両方は WWWTranscoder.URLEncode を介してエスケープされ、URL エンコードされたフォームのストリングに結合します。(例: key1=value1&key2=value2)

このメソッドはデフォルトでは DownloadHandlerBufferUnityWebRequest にアタッチします。これは利便性のために、特に REST API のケースでほとんどのユーザーがサーバーからの応答を確認する DownloadHandler を使用すると予想してます。

FormFields から生成される URL エンコードされたフォームストリングをバイトストリームに変換して UploadHandlerRaw に格納します。これは UnityWebRequest にアタッチされます。

no example available in JavaScript
using UnityEngine;
using UnityEngine.Experimental.Networking;
using System.Collections;
 
class MyBehavior: public MonoBehaviour {
    void Start() {
        StartCoroutine(Upload());
    }
 
    IEnumerator Upload() {
        WWWForm form = new WWWForm();
        form.AddField("myField", "myData");
 
        UnityWebRequest www = UnityWebRequest.Post("http://www.my-server.com/myform", form);
        yield return www.Send();
 
        if(www.isError) {
            Debug.Log(www.error);
        }
        else {
            Debug.Log("Form upload complete!");
        }
    }
}