BlazorMSAL没有请求范围
创始人
2024-12-21 12:00:28
0

Blazor中的MSAL(Microsoft身份验证库)可能无法正确请求所需的访问令牌范围。要解决此问题,您可以手动在代码中指定所需的访问令牌范围。

下面是一个代码示例,展示如何在Blazor中使用MSAL并请求特定的访问令牌范围:

@page "/secure"
@using Microsoft.AspNetCore.Components.WebAssembly.Authentication
@using Microsoft.Graph
@inject GraphServiceClient GraphClient
@inject RefreshTokenService TokenService




@if (initializing)
{
    

Loading...

} else if (context == null) {

You are not signed in.

} else {

Welcome, @context.User.Identity.Name! You have access to the following scopes:

    @foreach (var scope in context.Scopes) {
  • @scope
  • }
} @code { private bool initializing = true; private RemoteAuthenticationState authState; private AuthenticationState authStateFromModal; private IAccessTokenProvider TokenProvider; private GraphServiceClient graphClient; private AuthenticationResult context = null; protected override async Task OnInitializedAsync() { TokenProvider = (IAccessTokenProvider)TokenService; graphClient = GraphClient; authState = await TokenProvider.RequestAccessToken(); context = await TokenProvider.RequestAccessToken(new AccessTokenRequestOptions { Scopes = new[] { "user.read", "mail.send" } }); initializing = false; } private async Task SignIn() { authStateFromModal = await TokenProvider.RequestAccessToken(new AccessTokenRequestOptions { Scopes = new[] { "user.read", "mail.send" } }, authState); context = authStateFromModal.GetAuthenticationState(); StateHasChanged(); } private async Task SignOut() { await TokenProvider.ClearCache(); context = null; StateHasChanged(); } }

在上面的代码中,我们在OnInitializedAsync方法中使用MSAL的RequestAccessToken方法请求所需的访问令牌范围。在这种情况下,我们请求user.readmail.send访问令牌范围。

创建AuthConfig.cs文件 并添加以下代码:

public const string ClientId = "";
public const string Authority = "https://login.microsoftonline.com/";
public const string RedirectUri = "";
public const string GraphUri = "https://graph.microsoft.com/v1.0";

请将 "your-application-client-id","your-directory-tenant-id" 和 "your-application-redirect-uri" 替换为您的应用程序的相关信息。

在您的服务中注册以下内容:

builder.Services.AddMsalAuthentication(options =>
{
    options.ProviderOptions.Cache.CacheLocation = "localStorage";
    options.ProviderOptions.DefaultAccessTokenScopes.Add("user.read");
    options.ProviderOptions.DefaultAccessTokenScopes.Add("mail.read");
    options.ProviderOptions.DefaultAccessTokenScopes.Add("openid");
});

然后您需要在Startup.cs中启用并配置SPA服务,以使应用程序能够使用身份验证。

app.UseStaticFiles();
app.UseRouting();
app.UseAuthentication();
app

相关内容

热门资讯

黑科技攻略(德州之星)外挂辅助... 黑科技攻略(德州之星)外挂辅助神器(透视)透明挂教程(竟然有挂)1、起透看视 德州之星透明视辅助2、...
黑科技代打(wepOkE)黑科... 黑科技代打(wepOkE)黑科技透明挂辅助挂(透视)透牌教程(竟然真的是有挂)1、用户打开应用后不用...
黑科技系统!(aapokEr)... 黑科技系统!(aapokEr)透明挂辅助器,(AAPOkER)从来真的有挂,2025版教程(有挂技巧...
黑科技工具(we poker)... 黑科技工具(we poker)黑科技透明挂辅助软件(透视)黑科技教程(一直是真的有挂)1、不需要AI...
黑科技讲解!(德扑)外挂辅助a... 黑科技讲解!(德扑)外挂辅助app,(德扑)原来存在有挂,解密教程(有挂方法);致您一封信;亲爱德扑...
黑科技攻略(红龙扑克)外挂辅助... 黑科技攻略(红龙扑克)外挂辅助方法(透视)揭秘教程(其实有挂)1、红龙扑克透视辅助简单,红龙扑克软件...
黑科技有挂!(wEpoKe)软... 黑科技有挂!(wEpoKe)软件透明挂,(WePoKer)素来是有挂,解说技巧(有挂技巧),支持语音...
黑科技好牌(微扑克私人局)外挂... 黑科技好牌(微扑克私人局)外挂透视辅助神器(透视)新2025教程(总是是真的有挂);1、该软件可以轻...
黑科技插件!(wPK)透视辅助... 黑科技插件!(wPK)透视辅助器,(wpK)原生存在有挂,攻略教程(有挂教程);《WPK辅助透视》‌...
黑科技线上(WepOke)黑科... 黑科技线上(WepOke)黑科技透明挂辅助挂(透视)可靠技巧(一直真的是有挂)1、用户打开应用后不用...