Skip to content

Latest commit

 

History

History
124 lines (86 loc) · 5.84 KB

File metadata and controls

124 lines (86 loc) · 5.84 KB
title Require secure transfer to ensure secure connections
titleSuffix Azure Storage
description Learn how to require secure transfer for requests to Azure Storage. When you require secure transfer for a storage account, any requests originating from an insecure connection are rejected.
services storage
author normesta
ms.service azure-storage
ms.topic how-to
ms.date 04/02/2026
ms.author normesta
ms.subservice storage-common-concepts
ms.custom devx-track-azurecli
ms.devlang azurecli

Require secure transfer to ensure secure connections

You can configure your storage account to accept requests from secure connections only by setting the Secure transfer required property for the storage account. When you require secure transfer, any requests originating from an insecure connection are rejected. We recommend that you require secure transfer for all of your storage accounts.

When secure transfer is required, a call to an Azure Storage REST API operation must be made over HTTPS. Any request made over HTTP is rejected. By default, the Secure transfer required property is enabled when you create a storage account.

Azure Policy provides a built-in policy to ensure that secure transfer is required for your storage accounts. For more information, see the Storage section in Azure Policy built-in policy definitions.

For Azure Files, you can now control SMB and NFS encryption requirements independently using their respective per-protocol security settings. When Require encryption in transit is enabled, the Secure transfer required property only applies to REST/HTTPS traffic for Azure file shares. For new storage accounts created by using the Azure portal, Require encryption in transit is enabled by default for both SMB and NFS. Storage accounts created by using Azure PowerShell, Azure CLI, or the FileREST API initially set these values as Not selected to ensure backward compatibility.

Connecting to an Azure file share over SMB without encryption fails when secure transfer is required for the storage account. Examples of insecure connections include those made over SMB 2.1 or SMB 3.x without encryption.

Require secure transfer in the Azure portal

You can turn on the Secure transfer required property when you create a storage account in the Azure portal. You can also enable it for existing storage accounts.

Require secure transfer for a new storage account

  1. Sign into the Azure portal and go to Storage accounts. Select + Create.

  2. On the Advanced tab, under Security, select the Require secure transfer for REST API operations checkbox.

    Create storage account advanced tab

Require secure transfer for an existing storage account

  1. Select an existing storage account in the Azure portal.
  2. From the service menu, under Settings, select Configuration.
  3. Under Secure transfer required, select Enabled.
  4. Select Save.

Require secure transfer from code

To require secure transfer programmatically, set the enableHttpsTrafficOnly property to True on the storage account. You can set this property by using the Storage Resource Provider REST API, client libraries, or tools:

Require secure transfer with PowerShell

[!INCLUDE updated-for-az]

This sample requires the Azure PowerShell module Az version 0.7 or later. Run Get-Module -ListAvailable Az to find the version. If you need to install or upgrade, see Install Azure PowerShell module.

Run Connect-AzAccount to create a connection with Azure.

Use the following command line to check the setting:

Get-AzStorageAccount -Name "{StorageAccountName}" -ResourceGroupName "{ResourceGroupName}"
StorageAccountName     : {StorageAccountName}
Kind                   : Storage
EnableHttpsTrafficOnly : False
...

Use the following command line to enable the setting:

Set-AzStorageAccount -Name "{StorageAccountName}" -ResourceGroupName "{ResourceGroupName}" -EnableHttpsTrafficOnly $True
StorageAccountName     : {StorageAccountName}
Kind                   : Storage
EnableHttpsTrafficOnly : True
...

Require secure transfer with Azure CLI

[!INCLUDE sample-cli-install]

[!INCLUDE quickstarts-free-trial-note]

Use the following command to check the setting:

az storage account show -g {ResourceGroupName} -n {StorageAccountName}
{
  "name": "{StorageAccountName}",
  "enableHttpsTrafficOnly": false,
  "type": "Microsoft.Storage/storageAccounts"
  ...
}

Use the following command to enable the setting:

az storage account update -g {ResourceGroupName} -n {StorageAccountName} --https-only true
{
  "name": "{StorageAccountName}",
  "enableHttpsTrafficOnly": true,
  "type": "Microsoft.Storage/storageAccounts"
  ...
}

Next steps

Security recommendations for Blob storage