Legacy Documentation: Version 5.5
Sending a form to an HTTP server (POST)
Advanced operations: Using the LLAPI

Uploading raw data to an HTTP server (PUT)

Some modern web applications prefer that files be uploaded via the HTTP PUT verb. For this scenario, Unity provides the UnityWebRequest.PUT function.

This function takes two arguments. The first argument is a string and specifies the target URL for the request. The second argument may be either a string or a byte array, and specifies the payload data to be sent to the server.

Function signatures:

WebRequest.Put(string url, string data);
WebRequest.Put(string url, byte[] data);

Details

  • This function creates a UnityWebRequest and sets the content type to application/octet-stream.
  • This function attaches a standard DownloadHandlerBuffer to the UnityWebRequest. As with the POST functions, you can use this to return result data from your applications.
  • This function stores the input upload data in a standard UploadHandlerRaw object and attaches it to the UnityWebRequest. As a result, if using the byte[] function, changes made to the byte array performed after the UnityWebRequest.PUT call are not reflected in the data uploaded to the server.

Example

using UnityEngine;
using System.Collections;
using Unity.Networking;
 
class MyBehavior: MonoBehaviour {
    void Start() {
        StartCoroutine(Upload());
    }
 
    IEnumerator Upload() {
        byte[] myData = System.Text.Encoding.UTF8.GetBytes("This is some test data");
        UnityWebRequest www = UnityWebRequest.Put("http://www.my-server.com/upload", myData);
        yield return www.Send();
 
        if(www.isError) {
            Debug.Log(www.error);
        }
        else {
            Debug.Log("Upload complete!");
        }
    }
}
Sending a form to an HTTP server (POST)
Advanced operations: Using the LLAPI
Copyright © 2023 Unity Technologies
优美缔软件(上海)有限公司 版权所有
"Unity"、Unity 徽标及其他 Unity 商标是 Unity Technologies 或其附属机构在美国及其他地区的商标或注册商标。其他名称或品牌是其各自所有者的商标。
公安部备案号:
31010902002961