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

この記事は、チュートリアル「データセットにデータをプッシュする」の一部です。This article is part of a step-by-step walkthrough to push data into a dataset.

チュートリアル「データセットにデータをプッシュする」の手順 1アプリを Azure AD に登録する」では、クライアント アプリを Azure AD に登録しました。In step 1 of Push data into a dataset, Register the app with Azure AD, you registered a client app in Azure AD. この手順では、認証アクセス トークンを取得します。In this step, you get an authentication access token. Power BI アプリは Azure AD と統合されており、それによってセキュリティで保護されたサインインと承認をアプリで行うことができます。Power BI apps are integrated with Azure AD to provide secure sign in and authorization for your app. トークンを使って Azure AD に対して認証を行い、Power BI リソースにアクセスします。You use a token to authenticate to Azure AD and gain access to Power BI resources.

ここでは、認証アクセス トークンを取得する方法を説明します。Here's how to get an authentication access token.

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

: 作業を開始する前に、チュートリアル「データセットにデータをプッシュする」の前の手順を完了してください。NOTE: Before you get started, make sure you have followed the previous steps in the push data into a dataset walkthrough.

  1. Visual Studio 2015 で、 コンソール アプリケーション プロジェクトを作成します。In Visual Studio 2015, create a Console Application project.
  2. Azure AD Authentication Library for .NET NuGet パッケージをインストールします。Install the Azure AD Authentication Library for .NET NuGet package. .NET アプリで認証セキュリティ トークンを取得するには、このパッケージを使います。To get an authentication security token in a .NET app, you use this package. パッケージをインストールする方法を次に示します。Here's how to install the package:

    a.a. Visual Studio 2015 で、[ツール] > [NuGet パッケージ マネージャー] > [パッケージ マネージャー コンソール] を選びます。In Visual Studio 2015, choose Tools > NuGet Package Manager > Package Manager Console.

    b.b. [パッケージ マネージャー コンソール] で、「Install-Package Microsoft.IdentityModel.Clients.ActiveDirectory -Version 2.21.301221612」と入力します。In Package Manager Console, enter Install-Package Microsoft.IdentityModel.Clients.ActiveDirectory -Version 2.21.301221612.

  3. Program {...} クラスに、以下のコードを追加します。Add the code below into class Program {...}.
  4. "{ClientID}" を、アプリを登録したときに取得した クライアント ID で置き換えます。Replace "{ClientID}", with the Client ID you got when you registered the app. アプリを Azure AD に登録する」をご覧ください。See Register the app with Azure AD.
  5. Microsoft.IdentityModel.Clients.ActiveDirectory パッケージをインストールした後、Program.cs に「 using Microsoft.IdentityModel.Clients.ActiveDirectory; 」を追加します。After installing the Microsoft.IdentityModel.Clients.ActiveDirectory package, add using Microsoft.IdentityModel.Clients.ActiveDirectory; to Program.cs.
  6. コンソール アプリを実行し、Power BI アカウントにログインします。Run the Console App, and login to your Power BI account. コンソール ウィンドウにトークン文字列が表示されます。You should see a token string 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 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.windows.net/common/oauth2/authorize";

           //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);
           string token = authContext.AcquireToken(resourceUri, clientID, new Uri(redirectUri)).AccessToken;

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

           return token;
       }

       #endregion

認証トークンを取得すると、任意の Power BI 操作を呼び出せます。After you get an authentication token, you can call any Power BI operation. 次の手順では、データセットの作成操作を呼び出して、ダッシュボードにデータをプッシュするデータセットを作成する操作を説明します。The next step shows you how to call the Create Dataset operation to create a dataset to push data into a dashboard.

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

以下は、完全なコード リストです。Below is the complete code listing.

完全なコード リスト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 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.windows.net/common/oauth2/authorize";

            //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);
            string token = authContext.AcquireToken(resourceUri, clientID, new Uri(redirectUri)).AccessToken;

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

            return token;
        }

        #endregion

    }
}

次の手順 >Next Step >

次の手順Next steps

Power BI でデータセットを作成するCreate a dataset in Power BI
アプリを Azure AD に登録するRegister an app with Azure AD
Azure AD Authentication Library for .NET NuGet パッケージAzure AD Authentication Library for .NET NuGet package
Power BI データセットにデータをプッシュするPush data into a Power BI dataset
Power BI REST API の概要Overview of Power BI REST API
Power BI REST API リファレンスPower BI REST API reference
他にわからないことがある場合は、More questions? Power BI コミュニティを利用してくださいTry the Power BI Community