BlazorMSAL没有请求范围
创始人
2024-12-21 12:01:21
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个错误,导致这篇... 当保存文章时出现错误时,可以通过以下步骤解决问题:查看错误信息:查看错误提示信息可以帮助我们了解具体...
汇川伺服电机位置控制模式参数配... 1. 基本控制参数设置 1)设置位置控制模式   2)绝对值位置线性模...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
不一致的条件格式 要解决不一致的条件格式问题,可以按照以下步骤进行:确定条件格式的规则:首先,需要明确条件格式的规则是...
本地主机上的图像未显示 问题描述:在本地主机上显示图像时,图像未能正常显示。解决方法:以下是一些可能的解决方法,具体取决于问...
表格列调整大小出现问题 问题描述:表格列调整大小出现问题,无法正常调整列宽。解决方法:检查表格的布局方式是否正确。确保表格使...
表格中数据未显示 当表格中的数据未显示时,可能是由于以下几个原因导致的:HTML代码问题:检查表格的HTML代码是否正...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...