Search code examples
azureasp.net-web-api2azure-web-app-servicestatic-ip-addressvirtual-ip-address

Azure: Getting internal IP - for a WEBSITE - to create access restrictions


Background:

I'm hosting 2 separate Website instances - 1 for a WebAPI2 "API", and 1 as an MVC5 "Client" that consumes said API. I would like to restrict access for the "API" to the "Client" (there are multiple clients)

(I've only seen answers for Cloud Services or VMs, so wanted to ask if there was anything I could use for Websites. I don't want to use a cloud service or a VM, as the website is faster, lighter, cheaper - which is what I need.... could not find a firewall feature for Websites in Azure.)

Problem:

I believe I can limit access to the "API" by setting parameters in the project's Web.Config file. But nslookup in the command prompt yields the same IP Address for all azure websites under my account.

Question:

How do I find the right IP Address -- one that the "Client" website will use to access the "API" Website instance?

If there is a better way to restrict access...please do suggest it.


Solution

  • You cannot secure your site by IP ACLing as web sites in Azure are running in a multi-tenant environment and they share set of IP addresses (IP addresses are per DC).

    You need to rely on different security mechanisms (using some secret which only client/server know etc.).

    Hope that helps.

    You can also take a look at How to determine Azure website outgoing IP Address?

    Petr