未处理的拒绝(错误):无法加载'WebPortal'的设置-ASP.NET Core React

问题描述 投票:1回答:1

我创建一个ASP.NET Core 3 React项目,但不断收到此错误。

未处理的拒绝(错误):无法加载'WebPortal'的设置

获取https://localhost:44367/_configuration/WebPortal 401

未捕获(承诺)错误:无法加载'WebPortal'的设置

在AuthorizeService.ensureUserManagerInitialized(AuthorizeService.js:184)在异步AuthorizeService.getUser(AuthorizeService.js:24)在异步AuthorizeService.isAuthenticated(AuthorizeService.js:15)在异步Promise.all(索引0)在异步LoginMenu.populateState(LoginMenu.js:26)处

这里是弹出的错误(AuthorizeService.js):

    async ensureUserManagerInitialized() {
        if (this.userManager !== undefined) {
            return;
        }

        let response = await fetch(ApplicationPaths.ApiAuthorizationClientConfigurationUrl);

        if (!response.ok) {
            throw new Error('Could not load settings for '${ApplicationName}');
        }

        let settings = await response.json();
        settings.automaticSilentRenew = true;
        settings.includeIdTokenInSilentRenew = true;
        settings.userStore = new WebStorageStateStore({
            prefix: ApplicationName
        });

        this.userManager = new UserManager(settings);
        this.userManager.events.addUserSignedOut(async () => {
            await this.userManager.removeUser();
            this.updateState(undefined);
        });
    }

我的ApiAuthorizationConstants.js文件:

    export const ApplicationName = 'WebPortal';
    export const QueryParameterNames = {
      ReturnUrl: 'returnUrl',
      Message: 'message'
    };
    export const LogoutActions = {
      LogoutCallback: 'logout-callback',
      Logout: 'logout',
      LoggedOut: 'logged-out'
    };
    export const LoginActions = {
      Login: 'login',
      LoginCallback: 'login-callback',
      LoginFailed: 'login-failed',
      Profile: 'profile',
      Register: 'register'
    };
    const prefix = '/authentication';
    export const ApplicationPaths = {
       DefaultLoginRedirectPath: '/',
       ApiAuthorizationClientConfigurationUrl: '/_configuration/${ApplicationName}',
       ApiAuthorizationPrefix: prefix,
       Login: '${prefix}/${LoginActions.Login}',
       LoginFailed: '${prefix}/${LoginActions.LoginFailed}',
       LoginCallback: '${prefix}/${LoginActions.LoginCallback}',
       Register: '${prefix}/${LoginActions.Register}',
       Profile: '${prefix}/${LoginActions.Profile}',
       LogOut: '${prefix}/${LogoutActions.Logout}',
       LoggedOut: '${prefix}/${LogoutActions.LoggedOut}',
       LogOutCallback: '${prefix}/${LogoutActions.LogoutCallback}',
       IdentityRegisterPath: '/Identity/Account/Register',
       IdentityManagePath: '/Identity/Account/Manage'
     };

在控制台中,我看到:

Error console

有人可以帮我吗?

asp.net reactjs asp.net-core asp.net-core-identity
1个回答
0
投票

根据@Woodz和@Jack的评论,我调查了问题并找出了问题。问题是Home页面需要授权。我将在此处发布我的解决方案,这可能会对某人有所帮助。

问题原因

在我的[[Startup.cs类中,我为所有Controller启用了授权。参见下面的代码,

services.AddMvc(options => { //**************Add General Policy ********************* //User need to be a Authorized system user to access pages except allowAnonymous annotation var generalPolicy = new AuthorizationPolicyBuilder() .RequireAuthenticatedUser() .Build(); options.Filters.Add(new AuthorizeFilter(generalPolicy)); options.Filters.Add(new AutoValidateAntiforgeryTokenAttribute()); })

解决方案>>

  • OidcConfigurationController.cs]中的更改授权(添加AllowAnonymous

    annotation)。
[AllowAnonymous] public class OidcConfigurationController : Controller { private readonly ILogger<OidcConfigurationController> _logger; public OidcConfigurationController(IClientRequestParametersProvider clientRequestParametersProvider, ILogger<OidcConfigurationController> logger) { ClientRequestParametersProvider = clientRequestParametersProvider; _logger = logger; } public IClientRequestParametersProvider ClientRequestParametersProvider { get; } [HttpGet("_configuration/{clientId}")] public IActionResult GetClientRequestParameters([FromRoute]string clientId) { var parameters = ClientRequestParametersProvider.GetClientParameters(HttpContext, clientId); return Ok(parameters); } }

© www.soinside.com 2019 - 2024. All rights reserved.