Udostępnij przez


Wdróż usługę Azure Application Gateway z odbiornikiem przepuszczającym mTLS

W tym przewodniku Szybki start pokazano, jak wdrożyć usługę Azure Application Gateway przy użyciu wzajemnego przekazywania protokołu TLS (mTLS) przy użyciu szablonu usługi ARM i wersji 2025-03-01interfejsu API. W trybie przekazywania brama żąda certyfikatu klienta, ale nie weryfikuje go. Walidacja certyfikatu i wymuszanie zasad są wykonywane po stronie serwera.

Kluczowe funkcje

  • Kojarzenie profilu SSL z odbiornikiem dla przekazywania mTLS.
  • Certyfikat urzędu certyfikacji klienta nie jest wymagany w bramie.
  • verifyClientAuthMode obsługuje Strict i Passthrough.

Uwaga / Notatka

Obsługa portalu, programu PowerShell i interfejsu wiersza polecenia dla konfiguracji przekazywania jest obecnie niedostępna. W tym przewodniku użyj szablonów ARM.

Wymagania wstępne

  • Subskrypcja platformy Azure i grupa zasobów.
  • Zainstalowany interfejs wiersza polecenia platformy Azure.
  • Certyfikat SSL (zakodowany w formacie Base64 PFX) i hasło.
  • Klucz SSH dla administratora maszyny wirtualnej z systemem Linux (jeśli dotyczy).
  • Wersja 2025-03-01 interfejsu API dla właściwości przekazywania.

Wdrażanie usługi Application Gateway za pomocą odbiornika przekazywania mTLS

Ten szablon tworzy:

  • Sieć wirtualna z dwiema podsieciami (jedna delegowana do usługi Application Gateway).
  • Publiczny adres IP frontonu bramy.
  • Usługa Bramka Aplikacji (Standard_v2) z:
    • Certyfikat SSL i profil SSL do przekazywania certyfikatu klienta.
    • Odbiornik HTTPS i reguła routingu.
    • Pula backendowa wskazująca na usługę aplikacji. Zaktualizuj szablon przy użyciu szczegółów konfiguracji i dołącz prawidłowy certyfikat SSL.

Plik parametrów: deploymentParameters.json

{
    "$schema": "https://schema.management.azure.com/schemas/2015-01-01/deploymentParameters.json#",
    "contentVersion": "1.0.0.0",
    "parameters": {
        "addressPrefix": {
            "value": "10.0.0.0/16"
        },
        "subnetPrefix": {
            "value": "10.0.0.0/24"
        },
        "skuName": {
            "value": "Standard_v2"
        },
        "capacity": {
            "value": 2
        },
        "adminUsername": {
            "value": "ubuntu"
        },
        "adminSSHKey": {
            "value": "<your-ssh-public-key>"
        },
        "certData": {
            "value": "<Base64-encoded-PFX-data>"
        },
        "certPassword": {
            "value": "<certificate-password>"
        }
    }
}

Plik szablonu: deploymentTemplate.json

{
    "$schema": "https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#",
    "contentVersion": "1.0.0.0",
    "parameters": {
        "addressPrefix": {
            "defaultValue": "10.0.0.0/16",
            "type": "String",
            "metadata": {
                "description": "Address prefix for the Virtual Network"
            }
        },
        "subnetPrefix": {
            "defaultValue": "10.0.0.0/24",
            "type": "String",
            "metadata": {
                "description": "Subnet prefix"
            }
        },
        "skuName": {
            "defaultValue": "Standard_Medium",
            "type": "String",
            "metadata": {
                "description": "Sku Name"
            }
        },
        "capacity": {
            "defaultValue": 2,
            "type": "Int",
            "metadata": {
                "description": "Number of instances"
            }
        },
        "adminUsername": {
            "type": "String"
        },
		"adminSSHKey": {
            "type": "securestring"
        },
        "certData": {
            "type": "String",
            "metadata": {
                "description": "ssl cert data"
            }
        },
        "certPassword": {
            "type": "SecureString",
            "metadata": {
                "description": "ssl cert password"
            }
        }
    },
    "variables": {
        "applicationGatewayName": "mtlsAppGw",
        "idName": "identity",
        "publicIPAddressName": "mtlsPip",
        "virtualNetworkName": "mtlsVnet",
        "subnetName": "appgwsubnet",
        "vnetID": "[resourceId('Microsoft.Network/virtualNetworks',variables('virtualNetworkName'))]",
        "subnetRef": "[concat(variables('vnetID'),'/subnets/',variables('subnetName'))]",
        "publicIPRef": "[resourceId('Microsoft.Network/publicIPAddresses',variables('publicIPAddressName'))]",
        "applicationGatewayID": "[resourceId('Microsoft.Network/applicationGateways',variables('applicationGatewayName'))]",
        "apiVersion": "2025-03-01",
        "identityID": "[resourceId('Microsoft.ManagedIdentity/userAssignedIdentities',variables('idName'))]",
        "backendSubnetId": "[concat(variables('vnetID'),'/subnets/backendsubnet')]"
    },
    "resources": [
        {
            "type": "Microsoft.Network/virtualNetworks",
            "name": "[variables('virtualNetworkName')]",
            "apiVersion": "2024-07-01",
            "location": "[resourceGroup().location]",
            "properties": {
                "addressSpace": {
                    "addressPrefixes": [
                        "[parameters('addressPrefix')]"
                    ]
                },
                "subnets": [
                    {
                        "name": "[variables('subnetName')]",
                        "properties": {
                            "addressPrefix": "[parameters('subnetPrefix')]",
                             "delegations": [
                                {
                                    "name": "Microsoft.Network/applicationGateways",
                                    "properties": {
                                        "serviceName": "Microsoft.Network/applicationGateways"
                                    }
                                }
                            ]
                        }
                    },
                    {
                        "name": "backendSubnet",
                        "properties": {
                            "addressPrefix": "10.0.2.0/24"
                        }
                    }
                ]
            }
        },
        {
            "type": "Microsoft.Network/publicIPAddresses",
            "sku": {
                "name": "Standard"
            },
            "name": "[variables('publicIPAddressName')]",
            "apiVersion": "2024-07-01",
            "location": "[resourceGroup().location]",
            "properties": {
                "publicIPAllocationMethod": "Static"
            }
        },
        {
            "type": "Microsoft.Network/applicationGateways",
            "name": "[variables('applicationGatewayName')]",
            "apiVersion": "[variables('apiVersion')]",
            "location": "[resourceGroup().location]",
            "properties": {
                "sku": {
                    "name": "Standard_v2",
                    "tier": "Standard_v2",
                    "capacity": 3
                },
                "sslCertificates": [
                    {
                        "name": "sslCert",
                        "properties": {
                            "data": "[parameters('certData')]",
                            "password": "[parameters('certPassword')]"
                        }
                    }
                ],
                "sslPolicy": {
                    "policyType": "Predefined",
                    "policyName": "AppGwSslPolicy20220101"
                },
                "sslProfiles": [
                    {
                        "name": "sslnotrustedcert",
                        "id": "[concat(resourceId('Microsoft.Network/applicationGateways',  variables('applicationGatewayName')), '/sslProfiles/sslnotrustedcert')]",
                        "properties": {
                            "clientAuthConfiguration": {
                                "VerifyClientCertIssuerDN": false,
                                "VerifyClientRevocation": "None",
                                "VerifyClientAuthMode": "Passthrough"
                            }
                        }
                    }                   
                ],
                "gatewayIPConfigurations": [
                    {
                        "name": "appGatewayIpConfig",
                        "properties": {
                            "subnet": {
                                "id": "[variables('subnetRef')]"
                            }
                        }
                    }
                ],
                "frontendIPConfigurations": [
                    {
                        "name": "appGatewayFrontendIP",
                        "properties": {
                            "PublicIPAddress": {
                                "id": "[variables('publicIPRef')]"
                            }
                        }
                    }
                ],
                "frontendPorts": [
                    {
                        "name": "port2",
                        "properties": {
                            "Port": 444
                        }
                    }
                ],
                "backendAddressPools": [
                    {
                        "name": "pool2",
                        "properties": {
                            "BackendAddresses": [
							  {
                                "fqdn": "headerappgw-hsa5gjh8fpfebcfd.westus-01.azurewebsites.net"
                              }
							]
                        }
                    }
                ],
                "backendHttpSettingsCollection": [
                    {
                        "name": "settings2",
                        "properties": {
                            "Port": 80,
                            "Protocol": "Http"
                        }
                    }
                ],
                "httpListeners": [
                    {
                        "name": "listener2",
                        "properties": {
                            "FrontendIPConfiguration": {
                                "Id": "[concat(variables('applicationGatewayID'), '/frontendIPConfigurations/appGatewayFrontendIP')]"
                            },
                            "FrontendPort": {
                                "Id": "[concat(variables('applicationGatewayID'), '/frontendPorts/port2')]"
                            },
                            "Protocol": "Https",
                            "SslCertificate": {
                                "Id": "[concat(variables('applicationGatewayID'), '/sslCertificates/sslCert')]"
                            },
                            "sslProfile": {
                                "id": "[concat(variables('applicationGatewayID'), '/sslProfiles/sslnotrustedcert')]"
                            }
                        }
                    }
                ],
                "requestRoutingRules": [
                    {
                        "Name": "rule2",
                        "properties": {
                            "RuleType": "Basic",
                            "priority": 2000,
                            "httpListener": {
                                "id": "[concat(variables('applicationGatewayID'), '/httpListeners/listener2')]"
                            },
                            "backendAddressPool": {
                                "id": "[concat(variables('applicationGatewayID'), '/backendAddressPools/pool2')]"
                            },
                            "backendHttpSettings": {
                                "id": "[concat(variables('applicationGatewayID'), '/backendHttpSettingsCollection/settings2')]"
                            }
                        }
                    }
                ]
            },
            "dependsOn": [
                "[concat('Microsoft.Network/virtualNetworks/', variables('virtualNetworkName'))]",
                "[concat('Microsoft.Network/publicIPAddresses/', variables('publicIPAddressName'))]"
            ]
        }
    ]
}

Wdrażanie szablonu

az deployment group create \
  --resource-group <your-resource-group> \
  --template-file deploymentTemplate.json \
  --parameters @deploymentParameters.json

Zweryfikuj i przetestuj

Weryfikowanie wdrożenia

  • W witrynie Azure Portal sprawdź plik JSON zasobu usługi Application Gateway
  • Wybierz wersję interfejsu API 2025-03-01 i zweryfikuj sslprofile
  • Sprawdź, czy verifyClientAuthMode jest ustawione na "passthrough"
"sslProfiles": [
         {
             "name": "sslnotrustedcert",
             "id": "samplesubscriptionid",
             "etag": "W/\"851e4e20-d2b1-4338-9135-e0beac11aa0e\"",
             "properties": {
                 "provisioningState": "Succeeded",
                 "clientAuthConfiguration": {
                     "verifyClientCertIssuerDN": false,
                     "verifyClientRevocation": "None",
                     "verifyClientAuthMode": "Passthrough"
                 },
                 "httpListeners": [
                     {
                         "id": "samplesubscriptionid"
                     }
                 ]

Wysyłanie certyfikatu klienta do zaplecza

  • Jeśli musisz przekazać certyfikat klienta do zaplecza, skonfiguruj regułę przepisywania zgodnie z opisem w mutual-authentication-server-variables.

  • Jeśli klient wysłał certyfikat, to ponowne zapisywanie gwarantuje, że certyfikat klienta jest uwzględniony w nagłówkach żądania na potrzeby przetwarzania zaplecza.

Testowanie łączności

  • Połączenia należy ustanowić, nawet jeśli nie podano certyfikatu klienta.

Parametry przekazywania mTLS

Name Typ Description
verifyClientCertIssuerDN (nazwa wyróżniająca klientaCertIssuerDN) typ logiczny (boolowski) Weryfikowanie nazwy wystawcy certyfikatu klienta w bramie
verifyClientRevocation (weryfikacjaClientRevocation) options Weryfikowanie odwołania certyfikatów klienta
VerifyClientAuthMode options Ustawianie trybu certyfikatu klienta (Strict lub Passthrough)

Tryb przejścia: Brama żąda certyfikatu klienta, ale nie wymusza jego użycia. Zaplecze weryfikuje certyfikat i wymusza zasady.

Powiadomienie o zabezpieczeniach

To rozwiązanie jest klasyfikowane jako Poufne firmy Microsoft. Podczas wdrażania tego rozwiązania i zarządzania nim należy postępować zgodnie z najlepszymi rozwiązaniami dotyczącymi zabezpieczeń i obsługi danych w organizacji.