Upload files with IoT Hub

There are many scenarios where you can't easily map your device data into the relatively small device-to-cloud messages that IoT Hub accepts. For example, sending large media files like video; or, sending large telemetry batches, either uploaded by intermittently connected devices or aggregated and compressed to save bandwidth.

When you need to upload large files from a device, you can still use the security and reliability of IoT Hub. Instead of brokering messages through itself, however, IoT Hub acts as a dispatcher to an associated Azure storage account. IoT Hub can also provide notification to backend services when a device completes a file upload.

If you need help with deciding when to use reported properties, device-to-cloud messages, or file uploads, see Device-to-cloud communications guidance.

Important

File upload functionality on devices that use X.509 certificate authority (CA) authentication is in public preview, and preview mode must be enabled. It is generally available on devices that use X.509 thumbprint authentication or X.509 certificate attestation with Azure Device Provisioning Service. To learn more about X.509 authentication with IoT Hub, see Supported X.509 certificates.

File upload overview

An IoT hub facilitates file uploads from connected devices by providing them with shared access signature (SAS) URIs on a per-upload basis for a blob container and Azure storage account that are configured for file upload from the hub. There are three parts to using file uploads with IoT Hub:

  • Configuring an Azure storage account and blob container on your IoT hub.
  • Uploading files from devices.
  • Optionally, notifying backend services of completed file uploads.

Before you can use the file upload feature, you must associate an Azure storage account and blob container with your IoT hub. You can also configure settings that control how IoT Hub authenticates with Azure storage, the time-to-live (TTL) of the SAS URIs that the IoT hub hands out to devices, and file upload notifications to your backend services. To learn more, see Associate an Azure storage account with IoT Hub.

Devices follow a three-step process to upload a file to the associated blob container:

  1. The device initiates the file upload with the IoT hub. It passes the name of a blob in the request and gets a SAS URI and a correlation ID in return. The SAS URI contains a SAS token for Azure storage that grants the device read-write permission on the requested blob in the blob container. For more information, see Device: Initialize a file upload.

  2. The device uses the SAS URI to securely call Azure blob storage APIs to upload the file to the blob container. For more information, see Device: Upload file using Azure storage APIs.

  3. When the file upload is complete, the device notifies the IoT hub of the completion status using the correlation ID it received from IoT Hub when it initiated the upload. For more information, see Device: Notify IoT Hub of a completed file upload.

Backend services can subscribe to file upload notifications on the IoT hub's service-facing file upload notification endpoint. If you enabled these notifications on your IoT hub, it delivers them on this endpoint whenever a device notifies the hub that it completed a file upload. Services can use these notifications to trigger further processing of the blob data. For more information, see Service: File upload notifications.

The Azure IoT device and service SDKs fully support file upload. For more information, see File upload using an SDK.

File upload quotas and limits

IoT Hub imposes throttling limits on the number of file uploads that it can initiate in a given period. The threshold is based on the SKU and number of units of your IoT hub. Additionally, each device is limited to 10 concurrent active file uploads at a time. For more information, see IoT Hub quotas and throttling.

Associate an Azure storage account with IoT Hub

You must associate an Azure storage account and blob container with your IoT hub to use file upload features. All file uploads from devices registered with your IoT hub go to this container. To configure a storage account and blob container on your IoT hub, see Configure IoT Hub file uploads using the Azure portal, Configure IoT Hub file uploads using Azure CLI, or Configure IoT Hub file uploads using PowerShell. You can also use the IoT Hub management APIs to configure file uploads programmatically.

By default, Azure IoT Hub uses key-based authentication to connect and authorize with Azure Storage. You can also configure user-assigned or system-assigned managed identities to authenticate Azure IoT Hub with Azure Storage. Managed identities provide Azure services with an automatically managed identity in Microsoft Entra ID in a secure manner.

File upload is subject to Azure Storage's firewall settings. You need to ensure your devices can communicate with Azure storage according to your authentication configuration.

There are several other settings that control the behavior of file uploads and file upload notifications. The following sections list all of the settings available. Depending on whether you use the Azure portal, Azure CLI, PowerShell, or the management APIs to configure file uploads, some of these settings might not be available. Make sure to set the enableFileUploadNotifications setting if you want notifications sent to your backend services when a file upload completes.

IoT Hub storage and authentication settings

The following settings associate a storage account and container with your IoT hub and control how your hub authenticates with Azure storage. These settings don't affect how devices authenticate with Azure storage. You still need to connect your devices to storage using the SAS URI. Today the SAS URI is generated using connection string.

For information about configuring file upload to use identity-based authentication, see Configure file upload with managed identities.

Property Description Range and default
storageEndpoints.$default.authenticationType Controls how the IoT Hub authenticates with Azure storage. Possible values are keyBased and identityBased. Default: keyBased.
storageEndpoints.$default.connectionString The connection string to the Azure storage account to use for file uploads. Default: Empty string.
storageEndpoints.$default.containerName The name of the container to upload files to. Default: Empty string.
storageEndpoints.$default.identity The managed identity to use for identity-based authentication. Possible values are [system] for the system-assigned managed identity or a resource ID for a user-assigned managed identity. The value isn't used for key-based authentication. Default: null.

File upload settings

The following settings control file uploads from the device.

Property Description Range and default
storageEndpoints.$default.ttlAsIso8601 Default TTL for SAS URIs generated by IoT Hub. ISO_8601 interval up to 48 hours (minimum one minute). Default: one hour.

File upload notification settings

The following settings control file upload notifications to backend services.

Property Description Range and default
enableFileUploadNotifications Controls whether file upload notifications are written to the file notifications endpoint. Bool. Default: False.
fileNotifications.ttlAsIso8601 Default TTL for file upload notifications. ISO_8601 interval up to 48 hours (minimum one minute). Default: one hour.
fileNotifications.lockDuration Lock duration for the file upload notifications queue. 5 to 300 seconds. Default: 60 seconds.
fileNotifications.maxDeliveryCount Maximum delivery count for the file upload notification queue. 1 to 100. Default: 10.

File upload using an SDK

The following how-to guides provide complete, step-by-step instructions to upload files using the Azure IoT device and service SDKs. The guides show you how to use the Azure portal to associate a storage account with an IoT hub. The guides also contain code snippets or refer to samples that guide you through an upload.

How-to guide Device SDK example Service SDK example
.NET Yes Yes
Java Yes Yes
Node.js Yes Yes
Python Yes No (not supported)

Note

The C device SDK uses a single call on the device client to perform file uploads. For more information, see IoTHubDeviceClient_UploadToBlobAsync() and IoTHubDeviceClient_UploadMultipleBlocksToBlobAsync(). These functions perform all aspects of the file upload in a single call: initiating the upload, uploading the file to Azure storage, and notifying IoT Hub when it completes. This interaction means that, in addition to whatever protocol the device is using to communicate with IoT Hub, the device also needs to be able to communicate over HTTPS with Azure storage as these functions make calls to the Azure storage APIs.

Device: Initialize a file upload

The device calls the Create File Upload SAS URI REST API or the equivalent API in one of the device SDKs to initiate a file upload.

Supported protocols: HTTPS
Endpoint: {iot hub}.azure-devices.cn/devices/{deviceId}/files
Method: POST

{
    "blobName":"myfile.txt"
}

Property Description
blobName The name of the blob to generate the SAS URI for.

IoT Hub responds with a correlation ID and the elements of a SAS URI that the device can use to authenticate with Azure storage. This response is subject to the throttling limits and per-device upload limits of the target IoT hub.

{
    "correlationId":"MjAyMTA3MzAwNjIxXzBiNjgwOGVkLWZjNzQtN...MzYzLWRlZmI4OWQxMzdmNF9teWZpbGUudHh0X3ZlcjIuMA==",
    "hostName":"contosostorageaccount.blob.core.chinacloudapi.cn",
    "containerName":"device-upload-container",
    "blobName":"mydevice/myfile.txt",
    "sasToken":"?sv=2018-03-28&sr=b&sig=mBLiODhpKXBs0y9RVzwk1S...l1X9qAfDuyg%3D&se=2021-07-30T06%3A11%3A10Z&sp=rw"
}

Property Description
correlationId The identifier for the device to use when sending the file upload complete notification to IoT Hub.
hostName The Azure storage account host name for the storage account configured on the IoT hub
containerName The name of the blob container configured on the IoT hub.
blobName The location where the blob will be stored in the container. The name is in the following format: {device ID of the device making the request}/{blobName in the request}
sasToken A SAS token that grants read-write access on the blob with Azure storage. The token is generated and signed by IoT Hub.

When it receives the response, the device:

  • Saves the correlation ID to include in the file upload complete notification to IoT hub when it completes the upload.

  • Uses the other properties to construct a SAS URI for the blob that it uses to authenticate with Azure storage. The SAS URI contains the resource URI for the requested blob and the SAS token. It takes following form: https://{hostName}/{containerName}/{blobName}{sasToken} (The sasToken property in the response contains a leading '?' character.) The braces aren't included.

    For example, for the values returned in the previous sample, the SAS URI is, https://contosostorageaccount.blob.core.chinacloudapi.cn/device-upload-container/mydevice/myfile.txt?sv=2018-03-28&sr=b&sig=mBLiODhpKXBs0y9RVzwk1S...l1X9qAfDuyg%3D&se=2021-07-30T06%3A11%3A10Z&sp=rw

    For more information about the SAS URI and SAS token, see Create a service SAS in the Azure storage documentation.

Device: Upload file using Azure storage APIs

The device uses the Azure Blob Storage REST APIs or equivalent Azure storage SDK APIs to upload the file to the blob in Azure storage.

Supported protocols: HTTPS

The following example shows a Put Blob request to create or update a small block blob. Notice that the URI used for this request is the SAS URI returned by IoT Hub in the previous section. The x-ms-blob-type header indicates that this request is for a block blob. If the request is successful, Azure storage returns a 201 Created.

PUT https://contosostorageaccount.blob.core.chinacloudapi.cn/device-upload-container/mydevice/myfile.txt?sv=2018-03-28&sr=b&sig=mBLiODhpKXBs0y9RVzwk1S...l1X9qAfDuyg%3D&se=2021-07-30T06%3A11%3A10Z&sp=rw HTTP/1.1
Content-Length: 11
Content-Type: text/plain; charset=UTF-8
Host: contosostorageaccount.blob.core.chinacloudapi.cn
x-ms-blob-type: BlockBlob

hello world

Working with Azure storage APIs is beyond the scope of this article. In addition to the Azure Blob storage REST APIs linked previously in this section, you can explore the following documentation to help you get started:

Device: Notify IoT Hub of a completed file upload

The device calls the Update File Upload Status REST API or the equivalent API in one of the device SDKs when it completes the file upload. The device should update the file upload status with IoT Hub regardless of whether the upload succeeds or fails.

Supported protocols: HTTPS
Endpoint: {iot hub}.azure-devices.cn/devices/{deviceId}/files/notifications
Method: POST

{
    "correlationId": "MjAyMTA3MzAwNjIxXzBiNjgwOGVkLWZjNzQtN...MzYzLWRlZmI4OWQxMzdmNF9teWZpbGUudHh0X3ZlcjIuMA==",
    "isSuccess": true,
    "statusCode": 200,
    "statusDescription": "File uploaded successfully"
}

Property Description
correlationId The correlation ID received in the initial SAS URI request.
isSuccess A boolean that indicates whether the file upload was successful.
statusCode An integer that represents the status code of the file upload. Typically three digits; for example, 200 or 201.
statusDescription A description of the file upload status.

When it receives a file upload complete notification from the device, IoT Hub:

  • Triggers a file upload notification to backend services if file upload notifications are configured.

  • Releases resources associated with the file upload. If IoT Hub doesn't receive a notification, it maintains the resources until the SAS URI time-to-live (TTL) associated with the upload expires.

Service: File upload notifications

If file upload notifications are enabled on your IoT hub, your hub generates a notification message for backend services when it receives notification from a device that a file upload is complete. IoT Hub delivers these file upload notifications through a service-facing endpoint. The receive semantics for file upload notifications are the same as for cloud-to-device messages and have the same message life cycle. The service SDKs expose APIs to handle file upload notifications.

Supported protocols AMQP, AMQP-WS
Endpoint: {iot hub}.azure-devices.cn/messages/servicebound/fileuploadnotifications
Method GET

Each message retrieved from the file upload notification endpoint is a JSON record:

{
    "deviceId":"mydevice",
    "blobUri":"https://contosostorageaccount.blob.core.chinacloudapi.cn/device-upload-container/mydevice/myfile.txt",
    "blobName":"mydevice/myfile.txt",
    "lastUpdatedTime":"2021-07-31T00:26:50+00:00",
    "blobSizeInBytes":11,
    "enqueuedTimeUtc":"2021-07-31T00:26:51.5134008Z"
}
Property Description
enqueuedTimeUtc Timestamp indicating when the notification was created.
deviceId The Device ID of the device that uploaded the file.
blobUri The URI of the uploaded file.
blobName The name of the uploaded file. The name is in the following format: {device ID of the device}/{name of the blob}
lastUpdatedTime Timestamp indicating when the file was last updated.
blobSizeInBytes An integer that represents the size of the uploaded file in bytes.

Services can use notifications to manage uploads. For example, they can trigger their own processing of the blob data, trigger processing of the blob data using other Azure services, or log the file upload notification for later review.

Next steps