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

相关内容

热门资讯

事发当天!上饶辅助设备出租,真... 事发当天!上饶辅助设备出租,真是是真的辅助工具(有挂头条)-哔哩哔哩上饶辅助设备出租脚本下载中分为三...
随着!菠萝神辅助器app,一直... 随着!菠萝神辅助器app,一直是有辅助平台(有挂教程)-哔哩哔哩1、很好的工具软件,可以解锁游戏的菠...
推出新举措!兴动海满辅助,一贯... 您好,兴动海满辅助这款游戏可以开挂的,确实是有挂的,需要了解加去威信【136704302】很多玩家在...
做出回应!微乐贵阳捉鸡麻将挂软... 做出回应!微乐贵阳捉鸡麻将挂软件,果然真的是有辅助神器(有挂秘诀)-哔哩哔哩1、打开软件启动之后找到...
反观!九游破解辅助插件,都是真... 反观!九游破解辅助插件,都是真的有辅助神器(有挂秘籍)-哔哩哔哩九游破解辅助插件能透视中分为三种模型...
据文件显示!科米台州麻将辅助,... 据文件显示!科米台州麻将辅助,真是有挂辅助app(竟然有挂)-哔哩哔哩1、每一步都需要思考,不同水平...
今天上午!赣湘互娱挂,总是是有... 今天上午!赣湘互娱挂,总是是有辅助修改器(有挂详情)-哔哩哔哩1、在赣湘互娱挂插件功能辅助器技巧中,...
来临!广西友乐解码器辅助器,原... 来临!广西友乐解码器辅助器,原来真的是有辅助脚本(真的有挂)-哔哩哔哩1.广西友乐解码器辅助器 选牌...
来临!新天道辅助脚本,确实有挂... 来临!新天道辅助脚本,确实有挂辅助下载(有挂秘诀)-哔哩哔哩1、金币登录送、破产送、升级送、活动送。...
近期!青橙竞技卡五星辅助,好像... 近期!青橙竞技卡五星辅助,好像真的是有辅助脚本(竟然有挂)-哔哩哔哩1、用户打开应用后不用登录就可以...