Azure Virtual Desktop (AVD)

Configure Custom URL redirection for Windows Virtual Desktop – WVD

Table of Contents

By default, all users are accessing their browser-based virtual desktops is via the same link using a Microsoft URL which is same for all customer (https://rdweb.wvd.microsoft.com/webclient/index.html)

As this URL is a bit long as well as not that easy to memorize, most of entities will be looking for setting their own Custom URL using the corporate domain name. same idea as myapps.3tallah.com or mail. 3tallah.com, for sure it would be up to you to set your preferred subdomain name.

In this blogpost we are going to use Azure Functions, which allows you to execute your code in a serverless compute platform, and the consumption plan pricing includes a monthly free grant of 1 million requests, this would be saving you from the hassle of creating, configuring and securing an IIS virtual machine and will as the cost of compute.

So with that here’s what I’m going to cover in this demo

  1. Create your Function App
  2. Set HTTP Trigger
  3. Add the Custom domain
  4. Test and validate

Create your Function App

Open Create a Function App blade

  • Subscription: Select the subscription where the new Function App will be created.
  • Resource group: Create a new resource group or use an existing one.
  • Function App name: Enter globally unique name for the Function App (Ex.
    wvdwebredirect01)
  • Publish: Select (Code)
  • Runtime stack: .NET Core
  • Version: 3.1
  • Region: Select the (Region) where you want to create the Function App

When creating a function app, you must create or link to a general-purpose Azure Storage account that supports Blobs, Queue, and Table storage. Select The Operating System that’s recommended for you based on your selection of runtime stack, And The plan that dictates how your app scales, what features are enabled, and how it is priced.

  • Storage: Create a new Storage
    Account or use an existing one.
  • Operating system: Select (Windows),
  • Plan: Select (Consumption Servless)

Application Insights is a code-less attach to provide detailed observability into your application.

Don’t enable Application Insights as its not really required for this scenario.

Function app creation is completed and that gives us an app service that’s the function app itself, an app service plan which is the compute that it’s connected to when it runs, and there’s also a storage account here in case we need to store any data.

Set Function App Trigger

    1. Open
      Function App blade
    2. Click on the created Function App in our case (wvdwebredirection)
    3. Click on the Function tab > Click Add
    4. Click on the HTTP Trigger


    1. Give the New Trigger Function a Name ( Ex. WVDHttpTrigger )
    2. Select Funcation as Authorization level >
      Create


      1. Once created open Code + Test Tab, So that we’re going to just delete all the exist code and use Tom’s Code below
      2. Github Link
      3. Only change that you have to do is it change this part (“wvd.3tallah.com“) with yours
      4. Click Save > Click Get function URL > Copy the URL

  1. Go back the created Function App main blade in our case (wvdwebredirection)
  2. Click on the Proxies tab > Click Add > Give it a Name
  3. Route template just add (/)
  4. Backend URL: paste the Copied function URL > Click Create


Add the Custom domain

Last step is to add your corporate domain as a custom domain lets hit to Custom domains tab so we can configure and manage custom domains assigned to your app.

    1. Open
      Function App blade
    2. Click on the created Function App in our case (wvdwebredirection)
    3. Copy Function App URL and Custom Domain Verification ID
    4. Open your DNS Provider to Create new DNS Record.
    5. Create CNAME Record for this Function App URL in DNS provider.
Record type Host Value Comments
CNAME wvd .azurewebsites.net The domain mapping itself.
TXT asuid.wvd The verification ID you got earlier App Service accesses the asuid. TXT record to verify your ownership of the custom domain.


    1. Create TXT Record in DNS provider verify your ownership of the custom domain.


  1. Back to the Function App blade
  2. Click on the Custom domains tab > Click Add custom domain
  3. Enter your corporate URL (Ex. wvd.3tallah.com) > Click Validate

It’ll show that you do own your domain and the hostname is available and then you can click the add custom domain button and then added for HTTP but not for an SSL state so if you want you can add a SSL certificate and do a binding here or that you can make this secure I’m gonna skip this step because this is just my lab now we should be able to test.

Test and validate

Open http://wvd.3tallah.com

Resources:

Code that have been used in this demo is being developed by Tom Hickling

Mahmoud A. ATALLAH

Microsoft MVP | Speaker | Azure Service Delivery Lead at Bespin Global MEA, helping customers build successful Azure practices. Talks about #AzureCloud and #AI

Recent Posts

Gitex – Ensuring a Secure & Scalable AI-powered Solution with Azure

In this session, we will explore the architecture and best practices for building secure and…

3 months ago

Part 4: Data Exfiltration Playbook – Azure WAF Security Lab

Introduction Welcome to our comprehensive series on Azure Web Application Firewall (WAF) security! In this…

5 months ago

Part 3: Vulnerability Exploitation Playbook – Azure WAF vs XSS

Introduction Welcome to the third installment of our Azure Web Application Firewall (WAF) Security Lab…

5 months ago

Part 2: Reconnaissance Playbook – Testing Azure WAF Protection

Introduction Welcome to the second installment of our Azure Web Application Firewall (WAF) Security Lab…

6 months ago

Part 1: Lab Setup – Building Your Azure WAF Testing Environment

Introduction Welcome to the first installment of our four-part Azure Web Application Firewall (WAF) Security…

6 months ago

Azure Web Application Firewall: A Hands-on Security Lab Series

Introduction In today's digital landscape, protecting web applications from sophisticated attacks is crucial. Azure Web…

6 months ago