How to connect to a Azure storage account blob storage that has turned off public network access and cannot whitelist IP addresses using Azure Storage Explorer from a local machine on a different network

Tom 1 Reputation point
2024-02-26T15:37:35.7933333+00:00

I am moving some resources behind a virtual network to improve security. I have a storage account that has been disabled from public networks but that is connected to a virtual network. I have setup a CDN that has been able to connect to a blob container and display images stored there. At the moment, I can't connect to the blob container from my local machine using the Azure Storage Explorer or the Azure portal. I have tried setting up an Azure VPN Gateway using a point to site connection but I still receive the following error:

This request is not authorized to perform this operation.> This storage account's 'Firewalls & virtual networks' settings may be blocking access to storage services. Try adding your client IP address to the firewall exceptions, or by allowing access from 'all networks' instead of 'selected networks'.

As a last resort, I can whitelist my IP address and everything works. However, there are other people that require access from their local machines and this is not a sustainable solution. Is there a setting that the VPN requires in order to connect to the storage account? Will this approach work if I move some Azure SQL databases to the same virtual network?

Azure SQL Database
Azure Storage Explorer
Azure Storage Explorer
An Azure tool that is used to manage cloud storage resources on Windows, macOS, and Linux.
252 questions
Azure Storage Accounts
Azure Storage Accounts
Globally unique resources that provide access to data management services and serve as the parent namespace for the services.
3,090 questions
0 comments No comments
{count} votes

2 answers

Sort by: Most helpful
  1. Anand Prakash Yadav 7,785 Reputation points Microsoft Vendor
    2024-02-27T11:08:30.2933333+00:00

    Hello Tom,

    Thank you for posting your query here!

    You may need a Private Endpoint - basically a NIC dedicated to each resource, or in the case of the storage account or similar resource, a specific service of the resource. Using these for storage accounts and Azure SQL is well-documented, they will work just fine with the Azure VPN gateway assuming your DNS is configured correctly. More details here: https://learn.microsoft.com/en-us/azure/private-link/private-endpoint-overview 

    However, please note that for the storage account, you can disable key access and use identity-based access, and for Azure SQL you can accomplish basically the same thing by disabling local SQL authentication. There are at least two other negatives with private endpoints: they cost about $7/month per endpoint, and they substantially complicate any infrastructure as code or CICD you are doing.

    Similar issue posted here on SO: https://stackoverflow.com/questions/78062159/how-to-connect-to-a-azure-storage-account-blob-storage-that-has-turned-off-publi

    Do let us know if you have any further queries. I’m happy to assist you further.

    Please do not forget to "Accept the answer” and “up-vote” wherever the information provided helps you, this can be beneficial to other community members.


  2. Sumarigo-MSFT 45,776 Reputation points Microsoft Employee
    2024-02-29T16:01:07.0733333+00:00

    @Tom Adding more information to the above response

    If you have turned off public network access to your Azure storage account blob storage and cannot whitelist IP addresses, you can still connect to the storage account using Azure Storage Explorer from a local machine on a different network by following these steps:

    1. Connect to your virtual network using a VPN connection. You can set up a VPN gateway in Azure and configure a point-to-site VPN connection to connect to your virtual network.
    2. Configure a virtual network service endpoint for your storage account. This will allow traffic from your virtual network to access the storage account without going through the public internet. To do this, you can follow these steps: a. Go to the "Firewalls and virtual networks" settings for your storage account. b. Click on "Add existing virtual network" and select the virtual network that you want to connect to the storage account. c. Once the virtual network is added, click on "Add existing subnet" and select the subnet that you want to use for the service endpoint. d. Save the changes to the firewall settings.
    3. Open Azure Storage Explorer on your local machine and click on "Add an account".
    4. Select "Use a connection string" and enter the connection string for your storage account. You can find the connection string in the "Access keys" section of your storage account.
    5. Click on "Next" and enter a display name for your storage account.
    6. In the "Advanced" tab, select "Use virtual network service endpoint" and enter the private IP address of the storage account. You can find the private IP address in the "Firewalls and virtual networks" settings of your storage account.

    Click on "Connect" to connect to your storage account.

    For this error message is that the firewall settings for your storage account are blocking access from your local machine. You mentioned that you have already tried adding your client IP address to the firewall exceptions, but this may not be a sustainable solution if other people require access from their local machines. Another possible solution is to configure a virtual network service endpoint for your storage account. This will allow traffic from your virtual network to access the storage account without going through the public internet. To do this, you can follow these steps:

    1. Go to the "Firewalls and virtual networks" settings for your storage account.
    2. Click on "Add existing virtual network" and select the virtual network that you want to connect to the storage account.
    3. Once the virtual network is added, click on "Add existing subnet" and select the subnet that you want to use for the service endpoint.
    4. Save the changes to the firewall settings.

    After you have configured the virtual network service endpoint, you should be able to access the blob container from your local machine by connecting to the virtual network using a VPN connection. You mentioned that you have already set up a VPN gateway using a point-to-site connection, but you are still receiving the error message. One possible reason for this is that the VPN connection is not configured to use the virtual network service endpoint for the storage account. You may need to update the VPN configuration to use the service endpoint. Regarding your question about moving Azure SQL databases to the same virtual network, this should work as long as you configure the firewall settings for the SQL server to allow traffic from the virtual network. You can follow similar steps as above to add the virtual network to the firewall settings for the SQL server.

    To connect to a blob container from your local machine using the Azure Storage Explorer or the Azure portal when the storage account is behind a virtual network, you need to create a private endpoint for the storage account and add that virtual network to the trusted virtual networks list. Then, you can connect to the storage account using the private endpoint. Alternatively, you can permit traffic through the ISE outbound IPs on the storage account.

    Kindly let us know if you still have more questions on this. I wish to engage with you offline for a closer look and provide a quick and specialized assistance, please send an email with subject line “Attn:subm” to AzCommunity[at]Microsoft[dot]com referencing this thread and the Azure subscription ID, I will follow-up with you.  

    Please let us know if you have any further queries. I’m happy to assist you further.    

    ---Please do not forget to "Accept the answer” and “up-vote” wherever the information provided helps you, this can be beneficial to other community members.

    0 comments No comments

Your answer

Answers can be marked as Accepted Answers by the question author, which helps users to know the answer solved the author's problem.