手順 2: 認証アクセス トークンを取得するStep 2: Get an authentication access token

この記事は、シリーズ「Power BI データセットにデータをプッシュする」の 2 番目の手順です。This article is the second step in the series Push data into a Power BI dataset.

手順 1 では、Azure AD でクライアント アプリを登録しましたIn step 1, you registered a client app in Azure AD. この手順では、認証アクセス トークンを取得します。In this step, you get an authentication access token. Power BI アプリは、Azure Active Directory と統合されることで、アプリにセキュリティで保護されたサインインと認証を提供します。Power BI apps are integrated with Azure Active Directory to provide your app with secure sign in and authorization. アプリでは、トークンを使って Azure AD に対して認証を行い、Power BI リソースにアクセスします。Your app uses a token to authenticate to Azure AD and gain access to Power BI resources.

認証アクセス トークンを取得するGet an authentication access token

開始する前に、「Power BI データセットにデータをプッシュする」シリーズの前の手順を完了していることを確認してください。Before starting, make sure you've completed the previous step in the Push data into a Power BI dataset series.

この手順では、Visual Studio 2015 以降が必要です。This procedure requires Visual Studio 2015 or later.

  1. Visual Studio で、新しい C# コンソール アプリケーション プロジェクトを作成します。In Visual Studio, create a new C# Console Application project.

  2. Azure AD Authentication Library for .NET NuGet パッケージをインストールします。Install the Azure AD Authentication Library for .NET NuGet package. .Net アプリでは、認証セキュリティ トークンを取得するために、このパッケージが必要です。Your .Net app needs this package to get an authentication security token.

    a.a. [ツール] > [NuGet パッケージ マネージャー] > [パッケージ マネージャー コンソール] の順に選択します。Select Tools > NuGet Package Manager > Package Manager Console.

    b.b. Install-Package Microsoft.IdentityModel.Clients.ActiveDirectory -Version 2.21.301221612」と入力しますEnter Install-Package Microsoft.IdentityModel.Clients.ActiveDirectory -Version 2.21.301221612

    c.c. Program.cs に、using Microsoft.IdentityModel.Clients.ActiveDirectory; を追加します。In Program.cs, add using Microsoft.IdentityModel.Clients.ActiveDirectory;.

  3. 次の手順の後に一覧表示されているサンプル コードを Program.cs に追加します。Add the sample code listed after these steps to Program.cs.

  4. "{ClientID}" を、前のシリーズの記事で、アプリを登録したときに取得したクライアント ID で置き換えます。Replace "{ClientID}", with the Client ID you got in the previous series article when you registered your app.

  5. コンソール アプリを実行し、Power BI アカウントにサインインします。Run your console app and sign in to your Power BI account.

    コンソール ウィンドウにトークン文字列が表示されます。A token string should appear in the console window.

認証セキュリティ トークンを取得するサンプル コードSample code to get authentication security token

このコードを Program {...} に追加します。Add this code to Program {...}.

  • 操作を呼び出すためのトークン変数。A token variable to call operations:

    private static string token = string.Empty;
    
    static void Main(string[] args)
    {
    }
    
  • static void Main(string[] args) では、以下のように入力します。In static void Main(string[] args):

    static void Main(string[] args)
    {
      //Get an authentication access token
      token = GetToken();
    }
    
  • GetToken() メソッドを追加します。Add a GetToken() method:

       #region Get an authentication access token
       private static async Task<string> GetToken()
       {
           // TODO: Install-Package Microsoft.IdentityModel.Clients.ActiveDirectory -Version 2.21.301221612
           // and add using Microsoft.IdentityModel.Clients.ActiveDirectory

           //The client id that Azure AD created when you registered your client app.
           string clientID = "{Client_ID}";

           //RedirectUri you used when you register your app.
           //For a client app, a redirect uri gives Azure AD more details on the application that it will authenticate.
           // You can use this redirect uri for your client app
           string redirectUri = "https://login.live.com/oauth20_desktop.srf";

           //Resource Uri for Power BI API
           string resourceUri = "https://analysis.windows.net/powerbi/api";

           //OAuth2 authority Uri
           string authorityUri = "https://login.microsoftonline.net/common/";

           //Get access token:
           // To call a Power BI REST operation, create an instance of AuthenticationContext and call AcquireToken
           // AuthenticationContext is part of the Active Directory Authentication Library NuGet package
           // To install the Active Directory Authentication Library NuGet package in Visual Studio,
           //  run "Install-Package Microsoft.IdentityModel.Clients.ActiveDirectory" from the nuget Package Manager Console.

           // AcquireToken will acquire an Azure access token
           // Call AcquireToken to get an Azure token from Azure Active Directory token issuance endpoint
           AuthenticationContext authContext = new AuthenticationContext(authorityUri);
           var token = authContext.AcquireTokenAsync(resourceUri, clientID, new Uri(redirectUri)).Result.AccessToken;

           Console.WriteLine(token);
           Console.ReadLine();

           return token;
       }

       #endregion

認証トークンを取得すると、任意の Power BI 操作を呼び出せます。After you get an authentication token, you can call any Power BI operation.

このシリーズの次の手順では、Power BI でデータセットを作成する方法について説明します。The next article in this series shows you how to Create a dataset in Power BI.

完全なコード リストComplete code listing

using System;
using Microsoft.IdentityModel.Clients.ActiveDirectory;

namespace walkthrough_push_data
{
    class Program
    {
        private static string token = string.Empty;

        static void Main(string[] args)
        {

            //Get an authentication access token
            token = GetToken();

        }

        #region Get an authentication access token
        private static async Task<string> GetToken()
        {
            // TODO: Install-Package Microsoft.IdentityModel.Clients.ActiveDirectory -Version 2.21.301221612
            // and add using Microsoft.IdentityModel.Clients.ActiveDirectory

            //The client id that Azure AD created when you registered your client app.
            string clientID = "{Client_ID}";

            //RedirectUri you used when you register your app.
            //For a client app, a redirect uri gives Azure AD more details on the application that it will authenticate.
            // You can use this redirect uri for your client app
            string redirectUri = "https://login.live.com/oauth20_desktop.srf";

            //Resource Uri for Power BI API
            string resourceUri = "https://analysis.windows.net/powerbi/api";

            //OAuth2 authority Uri
            string authorityUri = "https://login.microsoftonline.com/common/";

            //Get access token:
            // To call a Power BI REST operation, create an instance of AuthenticationContext and call AcquireToken
            // AuthenticationContext is part of the Active Directory Authentication Library NuGet package
            // To install the Active Directory Authentication Library NuGet package in Visual Studio,
            //  run "Install-Package Microsoft.IdentityModel.Clients.ActiveDirectory" from the nuget Package Manager Console.

            // AcquireToken will acquire an Azure access token
            // Call AcquireToken to get an Azure token from Azure Active Directory token issuance endpoint
            AuthenticationContext authContext = new AuthenticationContext(authorityUri);
            var token = authContext.AcquireTokenAsync(resourceUri, clientID, new Uri(redirectUri)).Result.AccessToken;

            Console.WriteLine(token);
            Console.ReadLine();

            return token;
        }

        #endregion

    }
}

次のステップNext steps

他にわからないことがある場合は、More questions? Power BI コミュニティを利用してくださいTry the Power BI Community