Skip to content

Latest commit

 

History

History
277 lines (176 loc) · 20 KB

configure-ssl-app-service-certificate.md

File metadata and controls

277 lines (176 loc) · 20 KB
title description tags ms.topic ms.date ms.reviewer ms.author author
Add and manage App Service certificates
Create an App Service certificate and manage it. Renew, synchronize, and delete App Service certificates.
buy-ssl-certificates
tutorial
08/27/2024
yutlin
msangapu
msangapu-msft

Create and manage an App Service certificate for your web app

This article shows how to create an App Service certificate and perform management tasks like renewing, synchronizing, and deleting certificates. Once you have an App Service certificate, you can then import it into an App Service app. An App Service certificate is a private certificate that's managed by Azure. It combines the simplicity of automated certificate management and the flexibility of renewal and export options.

If you purchase an App Service certificate from Azure, Azure manages the following tasks:

  • Handles the purchase process from GoDaddy.
  • Performs domain verification of the certificate.
  • Maintains the certificate in Azure Key Vault.
  • Manages certificate renewal.
  • Synchronizes the certificate automatically with the imported copies in App Service apps.

Note

After you upload a certificate to an app, the certificate is stored in a deployment unit that's bound to the App Service plan's resource group, region, and operating system combination, internally called a webspace. That way, the certificate is accessible to other apps in the same resource group and region combination. Certificates uploaded or imported to App Service are shared with App Services in the same deployment unit.

Prerequisites

Note

Currently, App Service certificates aren't supported in Azure national clouds.

Buy and configure an App Service certificate

Buy the certificate

  1. Go to the Create App Service certificate page to start the purchase.

    [!NOTE] App Service Certificates purchased from Azure are issued by GoDaddy. For some domains, you must explicitly allow GoDaddy as a certificate issuer by creating a CAA domain record with the value 0 issue godaddy.com.

    :::image type="content" source="./media/configure-ssl-certificate/purchase-app-service-cert.png" alt-text="Screenshot of Create App Service certificate pane with purchase options.":::

  2. To configure the certificate, use the following table. When you're done, select Review + Create, and then select Create.

    Setting Description
    Subscription The Azure subscription to associate with the certificate.
    Resource Group The resource group that will contain the certificate. You can either create a new resource group or select the same resource group as your App Service app.
    SKU Determines the type of certificate to create, either a standard certificate or a wildcard certificate.
    Naked domain hostname Specify the root domain. The issued certificate provides security for both the root domain and the www subdomain. In the issued certificate, the Common Name field specifies the root domain, and the Subject Alternative Name field specifies the www domain. To provide security for only a subdomain, specify the fully qualified domain name for the subdomain, for example, mysubdomain.contoso.com.
    Certificate name The friendly name for your App Service certificate.
    Enable auto renewal Select whether to automatically renew the certificate before expiration. Each renewal extends the certificate expiration by one year. The cost is charged to your subscription.
  3. When deployment is complete, select Go to resource.

Store the certificate in Azure Key Vault

Key Vault is an Azure service that helps safeguard cryptographic keys and secrets used by cloud applications and services. For App Service certificates, we recommend that you use Key Vault. After you finish the certificate purchase process, you must complete a few more steps before you start using the certificate.

  1. On the App Service Certificates page, select the certificate. On the certificate menu, select Certificate Configuration > Step 1: Store.

    :::image type="content" source="media/configure-ssl-certificate/configure-key-vault.png" alt-text="Screenshot of the Certificate Configuration pane with 'Step 1: Store' selected.":::

  2. On the Key Vault Status page, select Select from Key Vault.

  3. If you create a new vault, set up the vault based on the following table, and make sure to use the same subscription and resource group as your App Service app.

    Setting Description
    Resource group Recommended: The same resource group as your App Service certificate.
    Key vault name A unique name that uses only alphanumeric characters and dashes.
    Region The same location as your App Service app.
    Pricing tier For information, see Azure Key Vault pricing details.
    Days to retain deleted vaults The number of days, after deletion, that objects remain recoverable. (See Azure Key Vault soft-delete overview.) Set a value between 7 and 90.
    Purge protection Enabling this option forces all deleted objects to remain in soft-deleted state for the entire duration of the retention period.
  4. Select Next and then select Vault access policy. Currently, App Service certificates support only Key Vault access policies, not the RBAC model.

  5. Select Review + create, and then select Create.

  6. After the key vault is created, don't select Go to resource. Wait for the Select key vault from Azure Key Vault page to reload.

  7. Select Select.

  8. After you select the vault, close the Key Vault Repository page. The Step 1: Store option should show a green check mark to indicate success. Keep the page open for the next step.

Confirm domain ownership

  1. From the same Certificate Configuration page as in the previous section, select Step 2: Verify.

    :::image type="content" source="media/configure-ssl-certificate/verify-domain.png" alt-text="Screenshot of the Certificate Configuration pane with 'Step 2: Verify' selected.":::

  2. Select App Service Verification. Because you mapped the domain to your web app earlier in this section, the domain is already verified. To finish this step, just select Verify, and then select Refresh until the message Certificate is Domain Verified appears.

The following domain verification methods are supported:

Method Description
App Service Verification The most convenient option when the domain is already mapped to an App Service app in the same subscription because the App Service app has already verified the domain ownership. Review the last step in Confirm domain ownership.
Domain Verification Confirm an App Service domain that you purchased from Azure. Azure automatically adds the verification TXT record for you and completes the process.
Mail Verification Confirm the domain by sending an email to the domain administrator. Instructions are provided when you select the option.
Manual Verification Confirm the domain by using either a DNS TXT record or an HTML page. (The latter applies only to Standard certificates. See the following note.) The steps are provided after you select the option. The HTML page option doesn't work for web apps with HTTPS Only enabled. For domain verification via DNS TXT record for either the root domain (for example, contoso.com) or the subdomain (for example, www.contoso.com or test.api.contoso.com) and regardless of the certificate SKU, you need to add a TXT record at the root domain level, using @ for the name and the domain verification token for the value in your DNS record.

Important

With the Standard certificate, you get a certificate for the requested top-level domain and the www subdomain, for example, contoso.com and www.contoso.com. However, App Service Verification and Manual Verification both use HTML page verification, which doesn't support the www subdomain when you issue, rekey, or renew a certificate. For the Standard certificate, use Domain Verification and Mail Verification to include the www subdomain with the requested top-level domain in the certificate.

Once your certificate is domain-verified, you're ready to import it into an App Service app.

Renew an App Service certificate

By default, App Service certificates have a one-year validity period. Before the expiration date, you can automatically or manually renew App Service certificates in one-year increments. The renewal process effectively gives you a new App Service certificate with the expiration date extended to one year from the existing certificate's expiration date.

Note

Starting September 23 2021, if you haven't verified the domain in the last 395 days, App Service certificates require domain verification during a renew, auto-renew, or rekey process. The new certificate order remains in "pending issuance" mode during the renew, auto-renew, or rekey process until you complete the domain verification.

Unlike the free App Service managed certificate, purchased App Service certificates don't have automated domain re-verification. Failure to verify domain ownership results in failed renewals. For more information about how to verify your App Service certificate, review Confirm domain ownership.

The renewal process requires that the service principal for App Service has the required permissions on your key vault. These permissions are set up for you when you import an App Service certificate through the Azure portal. Make sure that you don't remove these permissions from your key vault.

  1. To change the automatic renewal setting for your App Service certificate at any time, on the App Service Certificates page, select the certificate.

  2. On the left menu, select Auto Renew Settings.

  3. Select On or Off, and then select Save.

    If you turn on automatic renewal, certificates can start automatically renewing 32 days before expiration.

    :::image type="content" source="./media/configure-ssl-certificate/auto-renew-app-service-cert.png" alt-text="Screenshot of specified certificate's auto renewal settings." lightbox="./media/configure-ssl-certificate/auto-renew-app-service-cert.png":::

  4. To manually renew the certificate instead, select Manual Renew. You can request to manually renew your certificate 60 days before expiration, but certificates can't be issued for longer than 397 days.

  5. After the renew operation completes, select Sync.

    The sync operation automatically updates the hostname bindings for the certificate in App Service without causing any downtime to your apps.

    [!NOTE] If you don't select Sync, App Service automatically syncs your certificate within 24 hours.

Rekey an App Service certificate

If you think your certificate's private key is compromised, you can rekey your certificate. This action rotates the certificate with a new certificate issued from the certificate authority.

  1. On the App Service Certificates page, select the certificate. From the left menu, select Rekey and Sync.

  2. To start the process, select Rekey. This process can take 1-10 minutes to complete.

    :::image type="content" source="./media/configure-ssl-certificate/rekey-app-service-cert.png" alt-text="Screenshot of rekeying an App Service certificate." lightbox="./media/configure-ssl-certificate/rekey-app-service-cert.png":::

  3. You might also be required to reconfirm domain ownership.

  4. After the rekey operation completes, select Sync.

    The sync operation automatically updates the hostname bindings for the certificate in App Service without causing any downtime to your apps.

    [!NOTE] If you don't select Sync, App Service automatically syncs your certificate within 24 hours.

Export an App Service certificate

Because an App Service certificate is a Key Vault secret, you can export a copy as a PFX file, which you can use for other Azure services or outside of Azure.

Important

The exported certificate is an unmanaged artifact. App Service doesn't sync such artifacts when the App Service Certificate is renewed. You must export and install the renewed certificate where necessary.

  1. On the App Service Certificates page, select the certificate.

  2. On the left menu, select Export Certificate.

  3. Select Open Key Vault Secret.

  4. Select the certificate's current version.

  5. Select Download as a certificate.

Run the following commands in Azure Cloud Shell, or run them locally if you have installed Azure CLI. Replace the placeholders with the names that you used when you bought the App Service certificate.

secretname=$(az resource show \
    --resource-group <group-name> \
    --resource-type "Microsoft.CertificateRegistration/certificateOrders" \
    --name <app-service-cert-name> \
    --query "properties.certificates.<app-service-cert-name>.keyVaultSecretName" \
    --output tsv)

az keyvault secret download \
    --file appservicecertificate.pfx \
    --vault-name <key-vault-name> \
    --name $secretname \
    --encoding base64
$ascName = <app-service-cert-name>
$ascResource = Get-AzResource -ResourceType "Microsoft.CertificateRegistration/certificateOrders" -Name $ascName -ResourceGroupName <group-name> -ExpandProperties
$keyVaultSecretName = $ascResource.Properties.certificates[0].$ascName.KeyVaultSecretName
$CertBase64 = Get-AzKeyVaultSecret -VaultName <key-vault-name> -Name $keyVaultSecretName -AsPlainText
$CertBytes = [Convert]::FromBase64String($CertBase64)
Set-Content -Path appservicecertificate.pfx -Value $CertBytes -AsByteStream

The downloaded PFX file is a raw PKCS12 file that contains both the public and private certificates and has an import password that's an empty string. You can locally install the file by leaving the password field empty. You can't upload the file as-is into App Service because the file isn't password protected.

Use Azure Advisor for App Service certificate

App Service certificate is integrated with Azure Advisor to provide reliability recommendations for when your certificate requires domain verification. You must verify domain ownership for your certificate during renew, auto-renew, or rekey process if you haven't verified the domain in the last 395 days. To ensure you do not miss any certificate that requires verification or risk any certificate from expiring, you can utilize Azure Advisor to view and set up alerts for App Service certificate.

View Advisor recommendation

To view Advisor recommendation for App Service certificate:

  1. Navigate to the Azure Advisor page.

  2. From the left menu, select Recommendations > Reliability

  3. Select the filter option Type equals and search for App Service Certificates from the dropdown list. If the value does not exist on the dropdown menu, then that means no recommendation has been generated for your App Service certificate resources because none of them requires domain ownership verification.

Create Advisor Alerts

You [create Azure Advisor alerts on new recommendations] using different configurations. To set up Advisor Alerts specifically for App Service certificate so you can get notifications when your certificate requires domain ownership validation:

  1. Navigate to the Azure Advisor page.

  2. From the left menu, select Monitoring > Alerts (Preview)

  3. Click on + New Advisor Alert on the action bar at the top. This will open a new blade called "Create Advisor Alerts".

  4. Under Condition select the following:

    Configured by Recommendation Type
    Recommendation Type Domain verification required to issue your App Service Certificate
  5. Fill out the rest of the required fields, then select the Create alert button at the bottom.

Delete an App Service certificate

If you delete an App Service certificate, the delete operation is irreversible and final. The result is a revoked certificate, and any binding in App Service that uses the certificate becomes invalid.

  1. On the App Service Certificates page, select the certificate.

  2. From the left menu, select Overview > Delete.

  3. When the confirmation box opens, enter the certificate name, and then select OK.

Frequently asked questions

My App Service certificate doesn't have any value in Key Vault

Your App Service certificate is probably not yet domain-verified. Until domain ownership is confirmed, your App Service certificate isn't ready for use. As a Key Vault secret, it maintains an Initialize tag, and its value and content-type remain empty. When domain ownership is confirmed, the key vault secret shows a value and a content-type, and the tag changes to Ready.

I can't export my App Service certificate with PowerShell

Your App Service certificate is probably not yet domain-verified. Until domain ownership is confirmed, your App Service certificate isn't ready for use.

What changes does the App Service certificate creation process make to my existing key vault?

The creation process makes the following changes:

  • Adds two access policies in the vault:
    • Microsoft.Azure.WebSites (or Microsoft Azure App Service)
    • Microsoft certificate reseller CSM Resource Provider (or Microsoft.Azure.CertificateRegistration)
  • Creates a delete lock called AppServiceCertificateLock on the vault to prevent accidental deletion of the key vault.

Related content