Version: 2019.2
NetworkServerSimple
共通操作 - HLAPI の使用

UnityWebRequest

ノート: UNet は非推奨となり、今後 Unity から削除される予定です。新しいシステムが開発中です。詳細は ブログFAQ を参照してください。

UnityWebRequest は、HTTP のリクエストとレスポンスを構成するモジュラーシステムを提供します。UnityWebRequest システムの主要な役割は、Unity が Web ブラウザのバックエンドとの相互作用を可能にすることです。チャンクになった HTTP リクエスト、POST/PUT 操作のストリーミング、HTTP ヘッダやHTTP メソッド(GET、POST、PUT、DELETE)の完全な制御など需要の高い機能にも対応します。

システムは 2レイヤー (層) から構成されています。

  • High-Level API (HLAPI) は Low-level API の機能をラップし、よくある操作を実行するのに便利なインターフェースを提供しています。
  • Low-Level API (LLAPI) は、より上級レベルのユーザーのために柔軟性に優れたものを提供しています。

サポートされているプラットフォーム

UnityWebRequest システムは、ほとんどの Unity プラットフォームに対応しています。

  • Unity エディターとスタンドアロンプレイヤーの全バージョン
  • WebGL
  • モバイルプラットフォーム: iOS, Android
  • ユニバーサル Windows プラットフォーム
  • PS4 と PSVita
  • Xbox One
  • Nintendo Switch

アーキテクチャ

UnityWebRequest のエコシステムは 3つの Distinct 操作に HTTP トランザクションを分けます。

  • サーバーにデータを送信する
  • サーバーからのデータを受信する
  • HTTP フロー制御(リダイレクト、エラー処理、他)

上級レベルのユーザーによりよいインターフェースを提供するために、これらの操作はそれぞれ個々のオブジェクトによって制御されています。

  • UploadHandler のオブジェクトは、サーバーへのデータ転送処理を行います。
  • DownloadHandler のオブジェクトは、サーバーからのデータ受信、受信したデータのバッファリングや後処理を行います。
  • UnityWebRequest オブジェクトは、他の2つのオブジェクトを管理し、さらに HTTP フロー制御に関する処理を扱います。このオブジェクトによってヘッダ情報(custom header)や URL が定義され、エラーとリダイレクトの情報が格納されます。

指定された HTTP トランザクションに関する通常のコードフローは以下のとおりです。

  • Web Request のオブジェクトを作成
  • Web Request のオブジェクトを設定
    • カスタムヘッダの設定
    • HTTP メソッド(GET, POST, HEAD など、Android を除くすべてのプラットフォームでカスタムのメソッドが使用可能です)
    • URL を設定
  • (オプション) Upload Handler を作成しWeb Request にアタッチ
    • アップロードするデータを指定
    • HTTP フォームをアップロード
  • (オプション) Download Handler を作成しWeb Request にアタッチ
  • Web Request を送信
    • コルーチンの場合、Send() コールの結果を Yield し、リクエストが完了するのを待つこともできます
  • (オプション) Download Handler から受信データを読み取る
  • (オプション) UnityWebRequest オブジェクトからエラー情報、HTTP ステータスコードやレスポンス情報を読み取る

• 2017–05–16 Page amended

NetworkServerSimple
共通操作 - HLAPI の使用