2016-09-19 49 views
1

我一直試圖通過利用來自.NET sample app的AAD應用程序配置信息將ADAL集成到我的AngularJS SPA應用程序中,並且無法讓它進行身份驗證。我每次都得到404。ADAL和angularjs WITHOUT .NET生成HTTP 404

的示例應用程序的說明如下:

Step 2: Register the sample with your Azure Active Directory tenant 

    Sign in to the Azure management portal. 
    Click on Active Directory in the left hand nav. 
    Click the directory tenant where you wish to register the sample application. 
    Click the Applications tab. 
    In the drawer, click Add. 
    Click "Add an application my organization is developing". 
    Enter a friendly name for the application, for example "SinglePageApp-DotNet", select "Web Application and/or Web API", and click next. 
    For the sign-on URL, enter the base URL for the sample, which is by default https://localhost:44326/. 
    For the App ID URI, enter https://<your_tenant_name>/SinglePageApp-DotNet, replacing <your_tenant_name> with the name of your Azure AD tenant. 
    All done! Before moving on to the next step, you need to find the Client ID of your application. 

    While still in the Azure portal, click the Configure tab of your application. 
    Find the Client ID value and copy it to the clipboard. 
    Step 3: Enable the OAuth2 implicit grant for your application 

    By default, applications provisioned in Azure AD are not enabled to use the OAuth2 implicit grant. In order to run this sample, you need to explicitly opt in. 

    From the former steps, your browser should still be on the Azure management portal - and specifically, displaying the Configure tab of your application's entry. 
    Using the Manage Manifest button in the drawer, download the manifest file for the application and save it to disk. 
    Open the manifest file with a text editor. Search for the oauth2AllowImplicitFlow property. You will find that it is set to false; change it to true and save the file. 
    Using the Manage Manifest button, upload the updated manifest file. Save the configuration of the app. 
    Step 4: Configure the sample to use your Azure Active Directory tenant 

    Open the solution in Visual Studio 2013. 
    Open the web.config file. 
    Find the app key ida:Tenant and replace the value with your AAD tenant name. 
    Find the app key ida:Audience and replace the value with the Client ID from the Azure portal. 
    Open the file App/Scripts/App.js and locate the line adalAuthenticationServiceProvider.init(. 
    Replace the value of tenant with your AAD tenant name. 
    Replace the value of clientId with the Client ID from the Azure portal. 

當我配置我的應用程序,它看起來是這樣的:

adalProvider.init(
{ 
    instance: 'https://login.microsoftonline.com/', 
    tenant: 'http://mytenantname.onmicrosoft.com', 
    clientId: '000000000-583f-4218-b410-28c2acf00000', 
    extraQueryParameter: '12345', 
}, 
$httpProvider 
); 

然而,當我嘗試驗證我總是得到一個404應答我的應用程序無法識別。任何想法這裏有什麼錯誤?

回答

0

的問題是在承租人值:

  1. 承租人財產必須是一個URN,而不是一個URL,因此它不應該包含「http://」。
  2. 您必須在URN的末尾包含應用程序名稱以唯一標識目錄中的應用程序。

試試看看它是否有效。

+0

認真!就是這樣。固定! 'tenant:'mytenantname.onmicrosoft.com/testapp',' –