Sdílet prostřednictvím


Intune Data Warehouse ověřování jen pro aplikace

Aplikaci můžete nastavit pomocí ID Microsoft Entra a ověřit ji na Data Warehouse Intune. Tento proces je užitečný pro weby, aplikace a procesy na pozadí, kde by aplikace neměla mít přístup k přihlašovacím údajům uživatele. Pomocí následujícího postupu autorizujete aplikaci s ID Microsoft Entra pomocí OAuth 2.0.

Autorizace

Microsoft Entra ID používá OAuth 2.0 k autorizaci přístupu k webovým aplikacím a webovým rozhraním API v tenantovi Microsoft Entra. V této příručce se dozvíte, jak ověřit aplikaci pomocí jazyka C#. Tok autorizačního kódu OAuth 2.0 je popsaný v části 4.1 specifikace OAuth 2.0. Další informace najdete v tématu Autorizace přístupu k webovým aplikacím pomocí OAuth 2.0 a ID Microsoft Entra.

Azure KeyVault

Následující proces používá privátní metodu ke zpracování a převodu klíče aplikace. Tato privátní metoda má název SecureString. Jako alternativu můžete k uložení klíče aplikace použít Azure KeyVault. Další informace najdete v tématu Key Vault.

Vytvoření webové aplikace

V této části zadáte podrobnosti o webové aplikaci, na kterou chcete odkazovat na Intune. Webová aplikace je aplikace klient-server. Server poskytuje webovou aplikaci, která zahrnuje uživatelské rozhraní, obsah a funkce. Tento typ aplikace se udržuje samostatně na webu. Pomocí Intune udělíte webové aplikaci přístup k Intune. Tok dat je inicializován webovou aplikací.

  1. Přihlaste se do Centra pro správu Microsoft Intune.

  2. Vyberte Všechny služby>M365 Microsoft Entra ID>Microsoft Entra ID>Registrace aplikací.

  3. Kliknutím na Nová registracezobrazte podokno Zaregistrovat aplikaci .

  4. V podokně Zaregistrovat aplikaci přidejte podrobnosti o aplikaci:

    • Název aplikace, například Intune App-Only ověřování.
    • Typ podporovaného účtu.
    • Identifikátor URI přesměrování aplikace. Toto je umístění, na které uživatelé během procesu ověřování automaticky přecházet. Jsou povinni prokázat, že jsou tím, kým říkají, že jsou. Další informace najdete v tématu Co je přístup k aplikacím a jednotné přihlašování s ID Microsoft Entra?
  5. Klikněte na Zaregistrovat.

    Poznámka

    Zkopírujte ID aplikace (klienta) z podokna aplikace a použijte ho později.

Vytvoření klíče (hesla)

V této části Microsoft Entra ID vygeneruje hodnotu klíče pro vaši aplikaci.

  1. V podokně Registrace aplikací vyberte nově vytvořenou aplikaci, aby se zobrazilo podokno aplikace.

  2. V horní části podokna vyberte Certifikáty & tajné kódy a zobrazte podokno Certifikáty & tajné kódy .

  3. V podokně Certifikáty & tajné kódy vyberte Tajné kódy klienta.

  4. Přidejte popis klíče a dobu platnosti klíče.

  5. Kliknutím na Přidat uložte a aktualizujte klíče aplikace.

  6. Musíte zkopírovat vygenerovanou hodnotu klíče (v kódování base64).

    Poznámka

    Hodnota klíče zmizí po opuštění podokna Certifikáty & tajných kódů . Klíč nebude možné z tohoto podokna později načíst. Zkopírujte ho pro pozdější použití.

Udělení oprávnění aplikacím

V této části udělíte oprávnění aplikacím.

  1. Vyberte Oprávnění> rozhraní APIPřidat oprávnění>aplikaceIntune>.
  2. Zvolte možnost get_data_warehouse (Získat informace o datovém skladu z Microsoft Intune).
  3. Klikněte na Přidat oprávnění.
  4. V podokně Přidat přístup k rozhraní API klikněte na Hotovo.
  5. V podokně Oprávnění rozhraní API klikněte na Udělit souhlas správce a kliknutím na Ano při zvýšení úrovně aktualizujte všechna existující oprávnění, která už tato aplikace má.

Vygenerovat token

Pomocí sady Visual Studio vytvořte projekt konzolové aplikace (.NET Framework), který podporuje rozhraní .NET Framework a jako kódovací jazyk používá jazyk C#.

  1. Vyberte Soubor>Nový>projekt , aby se zobrazilo dialogové okno Nový projekt .

  2. Na levé straně vyberte Visual C# , aby se zobrazily všechny projekty .NET Framework.

  3. Vyberte Konzolová aplikace (.NET Framework), přidejte název aplikace a kliknutím na OK aplikaci vytvořte.

  4. V Průzkumník řešení vyberte Program.cs a zobrazte kód.

  5. V Průzkumník řešení přidejte odkaz na sestavení System.Configuration.

  6. V místní nabídce vyberte Přidat>novou položku. Zobrazí se dialogové okno Přidat novou položku .

  7. Na levé straně v části Visual C# vyberte Kód.

  8. Vyberte Třída, změňte název třídy na IntuneDataWarehouseClass.cs a klikněte na Přidat.

  9. Do metody přidejte následující kód Main :

         var applicationId = ConfigurationManager.AppSettings["appId"].ToString();
         SecureString applicationSecret = ConvertToSecureStr(ConfigurationManager.AppSettings["appKey"].ToString()); // Load as SecureString from configuration file or secret store (i.e. Azure KeyVault)
         var tenantDomain = ConfigurationManager.AppSettings["tenantDomain"].ToString();
         var msalContext = new AuthenticationContext($"https://login.windows.net/" + tenantDomain + "/oauth2/token");
    
         AuthenticationResult authResult = msalContext.AcquireTokenAsync(
             resource: "https://api.manage.microsoft.com/",
             clientCredential: new ClientCredential(
                 applicationId,
                 new SecureClientSecret(applicationSecret))).Result;
    
  10. Přidejte další obory názvů tak, že na začátek souboru kódu přidáte následující kód:

     using System.Security;
     using Microsoft.Identity.Client;
     using System.Configuration;
    

    Poznámka

    Musíte použít knihovnu MSAL (Microsoft Authentication Library). Další informace najdete v tématu Aktualizace aplikací tak, aby používaly knihovnu MSAL (Microsoft Authentication Library) a Microsoft Graph API.

  11. Za metodu Main přidejte následující privátní metodu pro zpracování a převod klíče aplikace:

    private static SecureString ConvertToSecureStr(string appkey)
    {
        if (appkey == null)
            throw new ArgumentNullException("AppKey must not be null.");
    
        var secureAppKey = new SecureString();
    
        foreach (char c in appkey)
            secureAppKey.AppendChar(c);
    
        secureAppKey.MakeReadOnly();
        return secureAppKey;
    }
    
  12. V Průzkumník řešení klikněte pravým tlačítkem na Odkazy a pak vyberte Spravovat balíčky NuGet.

  13. Vyhledejte Microsoft.Identity.Client a nainstalujte související balíček NuGet od Microsoftu.

  14. V Průzkumník řešení vyberte a otevřete soubor App.config.

  15. appSettings Přidejte oddíl tak, aby se xml zobrazil následujícím způsobem:

    <?xml version="1.0" encoding="utf-8" ?>
    <configuration>
        <startup> 
            <supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.6.1" />
        </startup>
        <appSettings>
          <add key="appId" value="App ID created from 'Create a Web App' procedure"/>
          <add key="appKey" value="Key created from 'Create a key' procedure" />
          <add key="tenantDomain" value="contoso.onmicrosoft.com"/>
        </appSettings>
    </configuration>
    
  16. appIdAktualizujte hodnoty , appKeya tenantDomain tak, aby odpovídaly jedinečným hodnotám souvisejícím s aplikací.

  17. Sestavte aplikaci.

    Poznámka

    Další kód implementace najdete v příkladu kódu Intune-Data-Warehouse.

Další kroky

Další informace o Azure Key Vault najdete v tématu Co je Azure Key Vault?