Solucionar problemas de formulários do ASP.NET Core Blazor
Observação
Esta não é a versão mais recente deste artigo. Para a versão atual, consulte a versão .NET 9 deste artigo.
Aviso
Esta versão do ASP.NET Core não tem mais suporte. Para obter mais informações, consulte a Política de Suporte do .NET e do .NET Core. Para a versão atual, consulte a versão .NET 9 deste artigo.
Importante
Essas informações relacionam-se ao produto de pré-lançamento, que poderá ser substancialmente modificado antes do lançamento comercial. A Microsoft não oferece nenhuma garantia, explícita ou implícita, quanto às informações fornecidas aqui.
Para a versão atual, consulte a versão .NET 9 deste artigo.
Este artigo fornece diretrizes de solução de problemas para formulários do Blazor.
Grandes conteúdo de formulário e o limite de tamanho da mensagem SignalR
Esta seção se aplica apenas a Blazor Web Apps, aplicativos do Blazor Server e soluções Blazor WebAssembly hospedadas que implementam SignalR.
Se o processamento do formulário falhar porque o conteúdo do formulário do componente excedeu o tamanho máximo da mensagem SignalR de entrada permitido para métodos de hub, o formulário poderá adotar interoperabilidade JS de streaming sem aumentar o limite de tamanho da mensagem. Para obter mais informações sobre o limite de tamanho e o erro gerado, consulte Diretrizes SignalR do Blazor do ASP.NET.
No exemplo a seguir, uma área de texto (<textarea>
) é usada com a interoperabilidade JS de streaming para mover até 50.000 bytes de dados para o servidor.
Adicione uma função getText
JavaScript (JS) ao aplicativo:
window.getText = (elem) => {
const textValue = elem.value;
const utf8Encoder = new TextEncoder();
const encodedTextValue = utf8Encoder.encode(textValue);
return encodedTextValue;
};
Para obter informações sobre onde colocar JS em um aplicativo Blazor, consulte Localização do JavaScript em aplicativos ASP.NET Core Blazor.
Devido a considerações de segurança, fluxos de comprimento zero não são permitidos para interoperabilidade JS de streaming. Portanto, o componente StreamFormData
a seguir intercepta um JSException e retorna uma cadeia de caracteres vazia se a área de texto estiver em branco quando o formulário for enviado.
StreamFormData.razor
:
@page "/stream-form-data"
@inject IJSRuntime JS
@inject ILogger<StreamFormData> Logger
<h1>Stream form data with JS interop</h1>
<EditForm FormName="StreamFormData" Model="this" OnSubmit="Submit">
<div>
<label>
<textarea> value streamed for assignment to
<code>TextAreaValue (<= 50,000 characters)</code>:
<textarea @ref="largeTextArea" />
</label>
</div>
<div>
<button type="submit">Submit</button>
</div>
</EditForm>
<div>
Length: @TextAreaValue?.Length
</div>
@code {
private ElementReference largeTextArea;
public string? TextAreaValue { get; set; }
protected override void OnInitialized() =>
TextAreaValue ??= string.Empty;
private async Task Submit()
{
TextAreaValue = await GetTextAsync();
Logger.LogInformation("TextAreaValue length: {Length}",
TextAreaValue.Length);
}
public async Task<string> GetTextAsync()
{
try
{
var streamRef =
await JS.InvokeAsync<IJSStreamReference>("getText", largeTextArea);
var stream = await streamRef.OpenReadStreamAsync(maxAllowedSize: 50_000);
var streamReader = new StreamReader(stream);
return await streamReader.ReadToEndAsync();
}
catch (JSException jsException)
{
if (jsException.InnerException is
ArgumentOutOfRangeException outOfRangeException &&
outOfRangeException.ActualValue is not null &&
outOfRangeException.ActualValue is long actualLength &&
actualLength == 0)
{
return string.Empty;
}
throw;
}
}
}
@page "/stream-form-data"
@inject IJSRuntime JS
@inject ILogger<StreamFormData> Logger
<h1>Stream form data with JS interop</h1>
<EditForm Model="this" OnSubmit="Submit">
<div>
<label>
<textarea> value streamed for assignment to
<code>TextAreaValue (<= 50,000 characters)</code>:
<textarea @ref="largeTextArea" />
</label>
</div>
<div>
<button type="submit">Submit</button>
</div>
</EditForm>
<div>
Length: @TextAreaValue?.Length
</div>
@code {
private ElementReference largeTextArea;
public string? TextAreaValue { get; set; }
protected override void OnInitialized() =>
TextAreaValue ??= string.Empty;
private async Task Submit()
{
TextAreaValue = await GetTextAsync();
Logger.LogInformation("TextAreaValue length: {Length}",
TextAreaValue.Length);
}
public async Task<string> GetTextAsync()
{
try
{
var streamRef =
await JS.InvokeAsync<IJSStreamReference>("getText", largeTextArea);
var stream = await streamRef.OpenReadStreamAsync(maxAllowedSize: 50_000);
var streamReader = new StreamReader(stream);
return await streamReader.ReadToEndAsync();
}
catch (JSException jsException)
{
if (jsException.InnerException is
ArgumentOutOfRangeException outOfRangeException &&
outOfRangeException.ActualValue is not null &&
outOfRangeException.ActualValue is long actualLength &&
actualLength == 0)
{
return string.Empty;
}
throw;
}
}
}
Se o processamento de formulário falhar porque o conteúdo do formulário do componente excedeu o tamanho máximo da mensagem de entrada SignalR permitido para métodos de hub, o limite de tamanho da mensagem poderá ser aumentado. Para obter mais informações sobre o limite de tamanho e o erro gerado, consulte Diretrizes SignalR do Blazor do ASP.NET.
Erro do parâmetro EditForm
InvalidOperationException: EditForm requer um parâmetro Model ou um parâmetro EditContext, mas não ambos.
Confirme se o EditForm atribui um Model ou um EditContext. Não use ambos para o mesmo formulário.
Ao atribuir Model, confirme se foi criada uma instância para o tipo de modelo.
Conexão desconectada
Erro: conexão perdida com 'Erro: o servidor retornou um erro ao fechar: conexão fechada com um erro.'.
System.IO.InvalidDataException: o tamanho máximo da mensagem de 32768B foi excedido. O tamanho da mensagem pode ser configurado em AddHubOptions.
Para obter mais informações e exemplos, confira os seguintes recursos: