我正在将Azure集成到我的应用程序中。我在Active Directory的Azure门户中创建了应用程序,并使用ADAL库进行了集成,但是当我运行获取Microsoft登录屏幕的应用程序时, 。在目录中找不到标识符
对于登录创建的按钮和的onclick按钮调用此
if (mResult != null) {
// logout
CookieManager cookieManager = CookieManager.getInstance();
cookieManager.removeAllCookie();
CookieSyncManager.getInstance().sync();
authenticationContext.getCache().removeAll();
} else {
// login
authenticationContext.acquireToken(LoginActivity.this,Constant.CLIENT_ID,
Constant.CLIENT_SECRETE_KEY, Constant.REDIRECT_URL, "", PromptBehavior.Auto, "",
callback);//CLIENT_ID=my appid at the of app registration //CLIENT_SECRETE_KEY=secret key of registered app in Active Directory //REDIRECT_URL=passing valid url
}
和回调的OnCreate LoginActivity
authenticationContext = new AuthenticationContext(LoginActivity.this,
Constant.AUTHORITY_URL, true);// Authority_URL=https://login.windows.net/mydirectoryname.onmicrosoft.com
的初始化authenticationcontext()
@Override
public void onActivityResult(int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data);
authenticationContext.onActivityResult(requestCode, resultCode, data);
}
private void showInfo(String msg) {
Log.e("", msg);
}
private AuthenticationCallback<AuthenticationResult> callback = new AuthenticationCallback<AuthenticationResult>() {
@Override
public void onError(Exception exc) {
showInfo("getToken Error:" + exc.getMessage());
}
@Override
public void onSuccess(AuthenticationResult result) {
mResult = result;
startActivity(new Intent(LoginActivity.this, SecondActivity.class));
if (mResult.getUserInfo() != null) {
Log.v("", "User info userid:" + result.getUserInfo().getUserId()
+ " displayableId:" + result.getUserInfo().getDisplayableId());
}
}
};
和Azure Portal在应用程序注册中获得了KEYVAULT和MicrosoftAzureActiveDirectory的许可(登录并阅读用户配置文件许可) 我做错了什么?
什么在Constant.ResourceId中传递以及代码中使用ClientSecretKey的位置 – sss
您不使用客户端密钥。您不能在移动应用中使用它,因为它们在不受信任的环境中运行。资源ID是您想要访问令牌的资源的URI。所以例如'https:// graph.windows.net /'用于Azure AD Graph API。 – juunas
authenticationContext.acquireToken(LoginActivity.this,Constant.RESOURCE_ID, Constant.CLIENT_ID,Constant.REDIRECT_URL,“”,PromptBehavior。Auto,“”, callback);我使用这个Authority_Url = https://login.windows.net/(mydirectoryname).onmicrosoft.com this Redirect_url =“https://(mydomainname)/ users/auth/azure_oauth2/callback” 这个资源id =“ https://login.windows.net/(mydirectory_id)/oauth2/token“ 但得到AADSTS50001错误* – sss