我有一个使用ASP.NET核心Web API的Angular应用程序。我使用ADAL进行身份验证,但现在应用程序也应该可供客户访问,因此我删除了ADAL代码并添加了与MSAL相关的代码。我创建了一个Azure AD B2C租户,并在应用程序中使用了这些凭据。当我现在运行应用程序时,我被重定向到Microsoft登录页面,这是完美的。但是当我在输入电子邮件和密码后登录时,它会登录到应用程序并立即将我重新定向到登录页面。我没有时间在Dev工具中调试问题。 msal.service.ts文件中的代码位于
之下private applicationConfig: any = {
clientID: 'XXXXXXXXXXXXXXXXXXXXXXXXXXX',
authority: 'XXXXXXXXXXXXXXXXXXXXXXXXXX',
b2cScopes: ['XXXXXXXXXXXXXXXXXXXXXXXXX'],
redirectUrl: 'XXXXXXXXXXXXXXXXXXXXXXXX'
};
private app: any;
public user: any;
constructor() {
this.app = new UserAgentApplication(this.applicationConfig.clientID, this.applicationConfig.authority,
(errorDesc, token, error, tokenType) => {
console.log(token);
}, { redirectUri: this.applicationConfig.redirectUrl });
// this.app.redirectUri=this.applicationConfig.redirectUrl;
}
public login() {
let tokenData = '';
this.app.loginRedirect(this.applicationConfig.b2cScopes).then(data => {tokenData = data; });
}
public getUser() {
const user = this.app.getUser();
if (user) {
return user;
} else {
return null;
}
}
public logout() {
this.app.logout();
}
public getToken() {
return this.app.acquireTokenSilent(this.applicationConfig.b2cScopes)
.then(accessToken => {
console.log(accessToken);
return accessToken;
}, error => {
return this.app.acquireTokenPopup(this.applicationConfig.b2cScopes)
.then(accessToken => {
return accessToken;
}, err => {
console.error(err);
});
});
}
auth.service.ts中的代码如下所示
constructor(private msalService: MSALService, public jwtHelper: JwtHelper) { }
public getToken(): string {
const token: string = window.sessionStorage.getItem('msal.idtoken');
return token;
}
public login() {
const token = this.getToken();
if (token == null || token === undefined || token === 'null') {
this.msalService.login();
}
}
public getTokenDecoded(): any
{
return this.jwtHelper.decodeToken(this.getToken());
}
我花了很多时间在这上面但无法确定问题的确切原因。请帮我解决这个问题
答案 0 :(得分:0)
要调试这些问题,请在控制台和网络选项卡中打开preserve log
:
网址中可能会显示一个错误,该错误应在网络标签中显示。
前: