web-dev-qa-db-ja.com

サーバー側BlazorでHttpContextにアクセスするにはどうすればよいですか?

ページ(.cshtml)のHttpContextにアクセスする必要があり、特にリクエストに続いてCookieにアクセスする必要があります。使用可能であるにもかかわらず、HttpContextAccessorには常にHttpContextプロパティにnull値が格納されています。

どんなアイデアでも大歓迎です。

前もって感謝します。

編集:私が使用するブレイザーのバージョンは0.7.0です。

12

次をBlazor.Web.App.Startup.csに追加します。

services.AddHttpContextAccessor();

これは<component-name>.cshtmlにも必要です

@using Microsoft.AspNetCore.Http
@inject IHttpContextAccessor httpContextAccessor
1
Issac

blazor.SeverからStartup.cs

public void ConfigureServices(IServiceCollection services)
{
    services.AddServerSideBlazor<Client.Startup>();

    // HttpContextAccessor
    services.AddHttpContextAccessor();
    services.AddScoped<HttpContextAccessor>();
}

blazor.Shared

public class HttpContextAccessor
{
   private readonly IHttpContextAccessor _httpContextAccessor;

   public HttpContextAccessor(IHttpContextAccessor httpContextAccessor)
   {
        _httpContextAccessor = httpContextAccessor;
   }

   public HttpContext Context => _httpContextAccessor.HttpContext;
}

blazor.ClientからApp.cshtmlへ

@inject blazor.Shared.HttpContextAccessor HttpContext
<Router AppAssembly=typeof(Program).Assembly />

@functions 
{      
    protected override void OnInit()
    {
       HttpContext.Context.Request.Cookies.**

       // Or data passed through middleware in blazor.Server
       HttpContext.Context.Features.Get<T>()
    }
}

クレジット: https://github.com/aspnet/Blazor/issues/1554

1
Flores

HttpContextにアクセスする目的によって異なります。

認証またはユーザー情報にアクセスする必要がある場合は、代わりに AuthenticationStateProvider の使用を検討してください。

@page "/"
@using System.Security.Claims
@using Microsoft.AspNetCore.Components.Authorization
@inject AuthenticationStateProvider AuthenticationStateProvider

<h3>ClaimsPrincipal Data</h3>

<button @onclick="GetClaimsPrincipalData">Get ClaimsPrincipal Data</button>

<p>@_authMessage</p>

@if (_claims.Count() > 0)
{
    <ul>
        @foreach (var claim in _claims)
        {
            <li>@claim.Type &ndash; @claim.Value</li>
        }
    </ul>
}

<p>@_surnameMessage</p>

@code {
    private string _authMessage;
    private string _surnameMessage;
    private IEnumerable<Claim> _claims = Enumerable.Empty<Claim>();

    private async Task GetClaimsPrincipalData()
    {
        var authState = await AuthenticationStateProvider.GetAuthenticationStateAsync();
        var user = authState.User;

        if (user.Identity.IsAuthenticated)
        {
            _authMessage = $"{user.Identity.Name} is authenticated.";
            _claims = user.Claims;
            _surnameMessage = 
                $"Surname: {user.FindFirst(c => c.Type == ClaimTypes.Surname)?.Value}";
        }
        else
        {
            _authMessage = "The user is NOT authenticated.";
        }
    }
}
0
Shimmy