ASP.NET Core Blazor formlara genel bakış
Uyarı
ASP.NET Core'un bu sürümü artık desteklenmiyor. Daha fazla bilgi için bkz . .NET ve .NET Core Destek İlkesi. Geçerli sürüm için bu makalenin .NET 9 sürümüne bakın.
Bu makalede, içindeki Blazorformların nasıl kullanılacağı açıklanmaktadır.
Giriş bileşenleri ve formları
Çerçeve Blazor formları destekler ve yerleşik giriş bileşenleri sağlar:
- Veri ek açıklamalarını kullanabilen bir nesneye veya modele bağlı.
- öğesini içeren
<form>
HTML formları. - EditForm Bileşen.
- öğesini içeren
- Yerleşik giriş bileşenleri.
- Veri EditForm ek açıklamalarını kullanabilen bir nesneye veya modele bağlı bileşen.
- Yerleşik giriş bileşenleri.
Not
Desteklenmeyen ASP.NET Temel doğrulama özellikleri, Desteklenmeyen doğrulama özellikleri bölümünde ele alınmıştır.
Ad Microsoft.AspNetCore.Components.Forms alanı aşağıdakileri sağlar:
- Form öğelerini, durumunu ve doğrulamasını yönetmeye yönelik sınıflar.
- Yerleşik Input* bileşenlere erişim.
Proje şablonundan Blazor oluşturulan bir proje, uygulamanın _Imports.razor
dosyasındaki ad alanını içerir ve bu da ad alanını uygulamanın Razor bileşenleri için kullanılabilir hale getirir.
Standart HTML formları desteklenir. Normal HTML <form>
etiketini kullanarak bir form oluşturun ve gönderilen form isteğini işlemek için bir @onsubmit
işleyici belirtin.
StarshipPlainForm.razor
:
@page "/starship-plain-form"
@inject ILogger<StarshipPlainForm> Logger
<form method="post" @onsubmit="Submit" @formname="starship-plain-form">
<AntiforgeryToken />
<div>
<label>
Identifier:
<InputText @bind-Value="Model!.Id" />
</label>
</div>
<div>
<button type="submit">Submit</button>
</div>
</form>
@code {
[SupplyParameterFromForm]
private Starship? Model { get; set; }
protected override void OnInitialized() => Model ??= new();
private void Submit() => Logger.LogInformation("Id = {Id}", Model?.Id);
public class Starship
{
public string? Id { get; set; }
}
}
@page "/starship-plain-form"
@inject ILogger<StarshipPlainForm> Logger
<form method="post" @onsubmit="Submit" @formname="starship-plain-form">
<AntiforgeryToken />
<div>
<label>
Identifier:
<InputText @bind-Value="Model!.Id" />
</label>
</div>
<div>
<button type="submit">Submit</button>
</div>
</form>
@code {
[SupplyParameterFromForm]
private Starship? Model { get; set; }
protected override void OnInitialized() => Model ??= new();
private void Submit() => Logger.LogInformation("Id = {Id}", Model?.Id);
public class Starship
{
public string? Id { get; set; }
}
}
Önceki StarshipPlainForm
bileşende:
- Form, öğenin göründüğü yerde
<form>
işlenir. Form, formu çerçeveye@formname
benzersiz olarak tanımlayan Blazor yönerge özniteliğiyle adlandırılır. - Model, bileşenin
@code
bloğunda oluşturulur ve bir ortak özellikte (Model
) tutulur. özniteliği,[SupplyParameterFromForm]
ilişkili özelliğin değerinin form verilerinden sağlanması gerektiğini gösterir. İstekteki, özelliğin adıyla eşleşen veriler özelliğine bağlıdır. - Bileşen InputText , dize değerlerini düzenlemeye yönelik bir giriş bileşenidir.
@bind-Value
yönerge özniteliği model özelliğini bileşeninModel.Id
özelliğine InputText bağlarValue. -
Submit
yöntemi, geri çağırma için@onsubmit
işleyici olarak kaydedilir. İşleyici, form kullanıcı tarafından gönderildiğinde çağrılır.
Önemli
Yönerge özniteliğini @formname
her zaman benzersiz bir form adıyla kullanın.
Blazor , yanıtı mevcut DOM'a uygulamak için isteği keserek sayfa gezintisini ve form işlemeyi geliştirir ve işlenen formun mümkün olduğunca çoğunu korur. Geliştirme, sayfayı tam olarak yükleme gereksinimini önler ve bileşen sunucuda işlenmiş olsa da tek sayfalı bir uygulamaya (SPA) benzer şekilde çok daha sorunsuz bir kullanıcı deneyimi sağlar. Daha fazla bilgi için bkz . ASP.NET Temel Blazor yönlendirme ve gezinti.
Akış işleme , düz HTML formları için desteklenir.
Not
.NET başvuru kaynağına yönelik belge bağlantıları genellikle deponun varsayılan dalını yükler ve bu dal .NET'in sonraki sürümü için geçerli geliştirmeyi temsil eder. Belirli bir sürümün etiketini seçmek için Dalları veya etiketleri değiştir açılan listesini kullanın. Daha fazla bilgi için bkz. ASP.NET Core kaynak kodunun sürüm etiketini seçme (dotnet/AspNetCore.Docs #26205).
Yukarıdaki örnek, forma bir AntiforgeryToken bileşen ekleyerek antiforgery desteğini içerir. Antiforgery desteği, bu makalenin Antiforgery desteği bölümünde daha ayrıntılı olarak açıklanmıştır.
Örneğin oninput
veya gibi başka bir öğenin DOM olaylarını temel alan bir form göndermek için JavaScript kullanarak formu gönderin (submit
).
Uygulamalarda düz formlar Blazor kullanmak yerine, bir form genellikle çerçevenin Blazor bileşeni kullanılarak 'nin yerleşik form desteğiyle EditFormtanımlanır. Aşağıdaki Razor bileşen, bir bileşeni kullanarak Razor bir web formunu işlemek için tipik öğeleri, bileşenleri ve EditForm kodu gösterir.
Form, çerçevenin BlazorEditForm bileşeni kullanılarak tanımlanır. Aşağıdaki Razor bileşen, bir bileşeni kullanarak Razor bir web formunu işlemek için tipik öğeleri, bileşenleri ve EditForm kodu gösterir.
Starship1.razor
:
@page "/starship-1"
@inject ILogger<Starship1> Logger
<EditForm Model="Model" OnSubmit="Submit" FormName="Starship1">
<div>
<label>
Identifier:
<InputText @bind-Value="Model!.Id" />
</label>
</div>
<div>
<button type="submit">Submit</button>
</div>
</EditForm>
@code {
[SupplyParameterFromForm]
private Starship? Model { get; set; }
protected override void OnInitialized() => Model ??= new();
private void Submit() => Logger.LogInformation("Id = {Id}", Model?.Id);
public class Starship
{
public string? Id { get; set; }
}
}
@page "/starship-1"
@inject ILogger<Starship1> Logger
<EditForm Model="Model" OnSubmit="Submit" FormName="Starship1">
<div>
<label>
Identifier:
<InputText @bind-Value="Model!.Id" />
</label>
</div>
<div>
<button type="submit">Submit</button>
</div>
</EditForm>
@code {
[SupplyParameterFromForm]
private Starship? Model { get; set; }
protected override void OnInitialized() => Model ??= new();
private void Submit() => Logger.LogInformation("Id = {Id}", Model?.Id);
public class Starship
{
public string? Id { get; set; }
}
}
Önceki Starship1
bileşende:
-
EditForm Bileşen, öğenin göründüğü yerde
<EditForm>
işlenir. Form, formu Blazor çerçevesine benzersiz olarak tanımlayan FormName özelliğiyle adlandırılır. - Model, bileşenin
@code
bloğunda oluşturulur ve bir ortak özellikte (Model
) tutulur. özelliği parametresine EditForm.Model atanır. özniteliği,[SupplyParameterFromForm]
ilişkili özelliğin değerinin form verilerinden sağlanması gerektiğini gösterir. İstekteki, özelliğin adıyla eşleşen veriler özelliğine bağlıdır. - Bileşen InputText , dize değerlerini düzenlemeye yönelik bir giriş bileşenidir .
@bind-Value
yönerge özniteliği model özelliğini bileşeninModel.Id
özelliğine InputText bağlarValue. -
Submit
yöntemi, geri çağırma için OnSubmit işleyici olarak kaydedilir. İşleyici, form kullanıcı tarafından gönderildiğinde çağrılır.
Önemli
FormName özelliğini her zaman benzersiz bir form adıyla kullanın.
Blazor , bileşenler için EditForm sayfa gezintisini ve form işlemeyi geliştirir. Daha fazla bilgi için bkz . ASP.NET Temel Blazor yönlendirme ve gezinti.
Akış işleme için desteklenir EditForm.
Not
.NET başvuru kaynağına yönelik belge bağlantıları genellikle deponun varsayılan dalını yükler ve bu dal .NET'in sonraki sürümü için geçerli geliştirmeyi temsil eder. Belirli bir sürümün etiketini seçmek için Dalları veya etiketleri değiştir açılan listesini kullanın. Daha fazla bilgi için bkz. ASP.NET Core kaynak kodunun sürüm etiketini seçme (dotnet/AspNetCore.Docs #26205).
@page "/starship-1"
@inject ILogger<Starship1> Logger
<EditForm Model="Model" OnSubmit="Submit">
<InputText @bind-Value="Model!.Id" />
<button type="submit">Submit</button>
</EditForm>
@code {
public Starship? Model { get; set; }
protected override void OnInitialized() => Model ??= new();
private void Submit()
{
Logger.LogInformation("Model.Id = {Id}", Model?.Id);
}
public class Starship
{
public string? Id { get; set; }
}
}
Önceki Starship1
bileşende:
-
EditForm Bileşen, öğenin göründüğü yerde
<EditForm>
işlenir. - Model, bileşenin
@code
bloğunda oluşturulur ve bir özel alanda (model
) tutulur. alanı parametresine EditForm.Model atanır. - Bileşen InputText , dize değerlerini düzenlemeye yönelik bir giriş bileşenidir.
@bind-Value
yönerge özniteliğiModel.Id
model özelliğini bileşenin InputText özelliğine Value bağlar†. -
Submit
yöntemi, geri çağırma için OnSubmit işleyici olarak kaydedilir. İşleyici, form kullanıcı tarafından gönderildiğinde çağrılır.
† Özellik bağlama hakkında daha fazla bilgi için bkz . ASP.NET Core Blazor veri bağlama.
Sonraki örnekte, önceki bileşen, bileşeninde Starship2
formu oluşturmak için değiştirilmiştir:
- OnSubmit , form kullanıcı tarafından gönderildiğinde geçerliyse atanan olay işleyicisini işleyen ile OnValidSubmitdeğiştirilir.
- ValidationSummary Form gönderiminde form geçersiz olduğunda doğrulama iletilerini görüntülemek için bir bileşen eklenir.
- Veri ek açıklamaları doğrulayıcı (DataAnnotationsValidator bileşen†), veri ek açıklamalarını kullanarak doğrulama desteği ekler:
-
<input>
Düğme seçildiğinde form alanı boşSubmit
bırakılırsa, doğrulama özetinde (ValidationSummarybileşen‡) ("The Id field is required.
") bir hata görüntülenir veSubmit
çağrılmaz. -
<input>
Düğme seçildiğinde form alanı on karakterden fazla karakterSubmit
içeriyorsa, doğrulama özetinde ("Id is too long.
") bir hata görüntülenir.Submit
çağrılmaz. -
<input>
Düğme seçildiğinde form alanı geçerli bir değerSubmit
içeriyorsa,Submit
çağrılır.
-
†BirleşenDataAnnotationsValidator, Validator bileşeni bölümünde ele alınmıştır. ValidationSummary‡Bileşen, Doğrulama Özeti ve Doğrulama İletisi bileşenleri bölümünde ele alınmıştır.
Starship2.razor
:
@page "/starship-2"
@using System.ComponentModel.DataAnnotations
@inject ILogger<Starship2> Logger
<EditForm Model="Model" OnValidSubmit="Submit" FormName="Starship2">
<DataAnnotationsValidator />
<ValidationSummary />
<label>
Identifier:
<InputText @bind-Value="Model!.Id" />
</label>
<button type="submit">Submit</button>
</EditForm>
@code {
[SupplyParameterFromForm]
private Starship? Model { get; set; }
protected override void OnInitialized() => Model ??= new();
private void Submit() => Logger.LogInformation("Id = {Id}", Model?.Id);
public class Starship
{
[Required]
[StringLength(10, ErrorMessage = "Id is too long.")]
public string? Id { get; set; }
}
}
@page "/starship-2"
@using System.ComponentModel.DataAnnotations
@inject ILogger<Starship2> Logger
<EditForm Model="Model" OnValidSubmit="Submit" FormName="Starship2">
<DataAnnotationsValidator />
<ValidationSummary />
<label>
Identifier:
<InputText @bind-Value="Model!.Id" />
</label>
<button type="submit">Submit</button>
</EditForm>
@code {
[SupplyParameterFromForm]
private Starship? Model { get; set; }
protected override void OnInitialized() => Model ??= new();
private void Submit() => Logger.LogInformation("Id = {Id}", Model?.Id);
public class Starship
{
[Required]
[StringLength(10, ErrorMessage = "Id is too long.")]
public string? Id { get; set; }
}
}
@page "/starship-2"
@using System.ComponentModel.DataAnnotations
@inject ILogger<Starship2> Logger
<EditForm Model="Model" OnValidSubmit="Submit">
<DataAnnotationsValidator />
<ValidationSummary />
<InputText @bind-Value="Model!.Id" />
<button type="submit">Submit</button>
</EditForm>
@code {
public Starship? Model { get; set; }
protected override void OnInitialized() => Model ??= new();
private void Submit()
{
Logger.LogInformation("Id = {Id}", Model?.Id);
}
public class Starship
{
[Required]
[StringLength(10, ErrorMessage = "Id is too long.")]
public string? Id { get; set; }
}
}
Form gönderimini işleme
form EditForm gönderimini işlemek için aşağıdaki geri çağırmaları sağlar:
- Geçerli alanları olan bir form gönderildiğinde çalıştırılacak bir olay işleyicisi atamak için kullanın OnValidSubmit .
- Geçersiz alanlara sahip bir form gönderildiğinde çalıştırılacak bir olay işleyicisi atamak için kullanın OnInvalidSubmit .
- Form alanlarının doğrulama durumundan bağımsız olarak çalıştırılacak bir olay işleyicisi atamak için kullanın OnSubmit . Form, olay işleyicisi yönteminde çağrılarak EditContext.Validate doğrulanır. döndürürse Validate
true
, form geçerli olur.
Form veya alanı temizleme
Modeli varsayılan durumuna geri döndürerek formu sıfırlayın; bu durum bir EditFormişaretlemenin içinde veya dışında gerçekleştirilebilir:
<button @onclick="ClearForm">Clear form</button>
...
private void ClearForm() => Model = new();
Alternatif olarak, açık Razor bir ifade kullanın:
<button @onclick="@(() => Model = new())">Clear form</button>
Model değerini varsayılan durumuna döndürerek bir alanı sıfırlayın:
<button @onclick="ResetId">Reset Identifier</button>
...
private void ResetId() => Model!.Id = string.Empty;
Alternatif olarak, açık Razor bir ifade kullanın:
<button @onclick="@(() => Model!.Id = string.Empty)">Reset Identifier</button>
Bir olay işleyicisi çağrıldıktan sonra bileşeni yeniden başlatmak için çerçeve tarafından StateHasChanged otomatik olarak çağrıldığından yukarıdaki örneklerde StateHasChanged çağrı Blazor yapmanız gerekmez. Bir form veya alanı temizleyen yöntemleri çağırmak için bir olay işleyicisi kullanılmıyorsa geliştirici kodu bileşeni yeniden oluşturmak için çağırmalıdır StateHasChanged .
Antiforgery desteği
Antiforgery hizmetleri, dosyada Blazor çağrıldığında AddRazorComponents uygulamalara otomatik olarak eklenirProgram
.
Uygulama, dosyadaki istek işleme işlem hattını UseAntiforgery çağırarak Program
Antiforgery Ara Yazılımını kullanır.
UseAntiforgery çağrısından sonra çağrılır UseRouting. ve UseRoutingçağrıları UseEndpoints varsa, çağrısı UseAntiforgery bunların arasına girmelidir. ve UseAntiforgeryçağrılarının UseAuthentication ardından için bir çağrı UseAuthorization yapılmalıdır.
Bileşen AntiforgeryToken , bir kötü amaçlı yazılımdan koruma belirtecini gizli bir alan olarak işler ve [RequireAntiforgeryToken]
özniteliği, kötü amaçlı yazılımdan korumayı etkinleştirir. Bir antiforgery denetimi başarısız olursa, bir 400 - Bad Request
yanıt oluşturulur ve form işlenmez.
tabanlı EditFormAntiforgeryToken formlar için bileşen ve [RequireAntiforgeryToken]
öznitelik otomatik olarak eklenerek kötü amaçlı yazılımdan koruma sağlanır.
HTML <form>
öğesini temel alan formlar için, bileşeni forma el ile ekleyin AntiforgeryToken :
<form method="post" @onsubmit="Submit" @formname="starshipForm">
<AntiforgeryToken />
<input id="send" type="submit" value="Send" />
</form>
@if (submitted)
{
<p>Form submitted!</p>
}
@code{
private bool submitted = false;
private void Submit() => submitted = true;
}
Uyarı
ya da EditForm HTML <form>
öğesini temel alan formlar için, özniteliğine required: false
geçirilerek [RequireAntiforgeryToken]
sahte koruma devre dışı bırakılabilir. Aşağıdaki örnek, sahteciliği devre dışı bırakır ve genel uygulamalar için önerilmez :
@using Microsoft.AspNetCore.Antiforgery
@attribute [RequireAntiforgeryToken(required: false)]
Daha fazla bilgi için bkz . ASP.NET Çekirdek Blazor kimlik doğrulaması ve yetkilendirme.
Fazla paylaşım saldırılarını azaltma
Genellikle form modeline sahip bir veritabanında kayıt oluşturan ve düzenleyen bileşenlerde kullanılanlar gibi statik olarak işlenmiş sunucu tarafı formlar, toplu atama saldırısı olarak da bilinen aşırı paylaşım saldırısına karşı savunmasız olabilir. Kötü amaçlı bir kullanıcı, işlenen formun parçası olmayan özellikler için verileri işleyen ve geliştiricinin kullanıcıların değiştirmesine izin vermek istemediği bir HTML formu POST'unu sunucuya yayınladığında bir paylaşım saldırısı oluşur. "Overposting" terimi, kötü amaçlı kullanıcının formla aşırı poz verdiği anlamına gelir.
Model oluşturma ve güncelleştirme işlemleri için kısıtlanmış özellikler içermediğinde aşırı paylaşım önemli değildir. Ancak, bakımını yaptığınız statik SSR tabanlı Blazor formlarla çalışırken üst paylaşıma dikkat etmek önemlidir.
Fazla göndermeyi azaltmak için oluşturma (ekleme) ve güncelleştirme işlemleriyle form ve veritabanı için ayrı bir görünüm modeli/veri aktarım nesnesi (DTO) kullanmanızı öneririz. Form gönderildiğinde, veritabanını değiştirmek için bileşen ve C# kodu tarafından yalnızca görünüm modelinin/DTO'nun özellikleri kullanılır. Kötü amaçlı bir kullanıcı tarafından eklenen tüm ek veriler atılır, bu nedenle kötü amaçlı kullanıcının aşırı paylaşım saldırısı gerçekleştirmesi engellenir.
Gelişmiş form işleme
EditForm geliştirin data-enhance
(<form>
):
<EditForm ... Enhance ...>
...
</EditForm>
<form ... data-enhance ...>
...
</form>
Desteklenmeyen: Gelişmiş form işlemeyi etkinleştirmek için formun atası öğesinde gelişmiş gezinti ayarlayamazsınız.
<div ... data-enhance ...>
<form ...>
<!-- NOT enhanced -->
</form>
</div>
Gelişmiş form gönderileri yalnızca uç noktalarla Blazor çalışır. Gelişmiş formu uç nokta olmayanBlazor bir forma göndermek hatayla sonuçlanır.
Gelişmiş form işlemeyi devre dışı bırakmak için:
- için EditForm, parametresini Enhance form öğesinden kaldırın (veya olarak
false
ayarlayın:Enhance="false"
). - HTML
<form>
için, form öğesinden özniteliğini kaldırındata-enhance
(veya olarakfalse
ayarlayın:data-enhance="false"
).
Blazor'nin gelişmiş gezintisi ve form teslimi, güncelleştirilmiş içerik sunucu işlemenin parçası değilse DOM'da yapılan dinamik değişiklikleri geri alabilir. Bir öğenin içeriğini korumak için özniteliğini data-permanent
kullanın.
Aşağıdaki örnekte, sayfa yüklendiğinde öğenin içeriği <div>
bir betik tarafından dinamik olarak güncelleştirilir:
<div data-permanent>
...
</div>
Gelişmiş gezinti ve form işlemeyi genel olarak devre dışı bırakmak için bkz . ASP.NET Core Blazor başlatma.
Gelişmiş sayfa güncelleştirmelerini dinlemek için olayı kullanma enhancedload
hakkında yönergeler için bkz . ASP.NET Temel Blazor yönlendirme ve gezinti.
Örnekler
Örnekler, form POST istekleri için gelişmiş form işlemeyi benimsemez, ancak tüm örnekler Gelişmiş form işleme bölümündeki yönergeleri izleyerek gelişmiş özellikleri benimseyecek şekilde güncelleştirilebilir.
Örneklerde, C# 9.0 ve .NET 5 ile tanıtılan hedef türündeki new
işleç kullanılır. Aşağıdaki örnekte, türü işleç için new
açıkça belirtilmeyen:
public ShipDescription ShipDescription { get; set; } = new();
C# 8.0 veya önceki bir sürüm (ASP.NET Core 3.1) kullanıyorsanız, türü işleç olarak belirtmek için new
örnek kodu değiştirin:
public ShipDescription ShipDescription { get; set; } = new ShipDescription();
Bileşenler null atanabilir başvuru türlerini (NTS) kullanır ve .NET derleyicisi null durum statik çözümlemesi gerçekleştirir ve her ikisi de .NET 6 veya sonraki sürümlerde desteklenir. Daha fazla bilgi için, bkz. ASP.NET Core 5.0'den 6.0'a geçiş.
C# 9.0 veya öncesi (.NET 5 veya öncesi) kullanıyorsanız, örneklerden NRT'leri kaldırın. Genellikle, bu yalnızca soru işaretlerinin (?
) ve ünlem noktalarının (!
) örnek koddaki türlerden kaldırılmasını içerir.
.NET SDK,.NET 6 veya üzerini hedeflerken projelere örtük genel using
yönergeler uygular. Örneklerde form işleme hakkındaki bilgileri günlüğe kaydetmek için günlükçü kullanılır, ancak bileşen örneklerinde ad alanı için @using
bir Microsoft.Extensions.Logging yönerge belirtmek gerekmez. Daha fazla bilgi için bkz . .NET proje SDK'ları: Örtük kullanım yönergeleri.
C# 9.0 veya öncesi (.NET 5 veya öncesi) kullanıyorsanız, örneğin gerektirdiği herhangi bir API için yönergeden @using
sonra bileşenin en üstüne yönergeleri ekleyin@page
. Visual Studio aracılığıyla API ad alanlarını bulun (nesneye sağ tıklayın ve Tanıma Göz At'ı seçin) veya .NET API tarayıcısı.
Formların veri ek açıklamaları doğrulamasıyla nasıl çalıştığını göstermek için örnek bileşenler API'yi System.ComponentModel.DataAnnotations kullanır. Veri ek açıklamalarını kullanan bileşenlerde fazladan bir kod satırından kaçınmak istiyorsanız, ad alanını uygulamanın bileşenlerinde içeri aktarma dosyasıyla (_Imports.razor
):
@using System.ComponentModel.DataAnnotations
Form örnekleri, Star Trek evreninin referans yönleridir. Star Trek, CBS Studios ve Paramount'un telif hakkı ©1966-2023'tür.
İstemci tarafı doğrulama için bir bağlantı hattı gerekir
s'de Blazor Web App, istemci tarafı doğrulama için etkin BlazorSignalR bir bağlantı hattı gerekir. İstemci tarafı doğrulaması, statik sunucu tarafı işlemeyi (statik SSR) benimseyen bileşenlerdeki formlar için kullanılamaz. Statik SSR'yi benimseyen formlar, form gönderildikten sonra sunucuda doğrulanır.
Desteklenmeyen doğrulama özellikleri
jQuery doğrulaması bileşenlerde Razor desteklenmez. Aşağıdaki yaklaşımlardan herhangi birini öneririz:
- aşağıdakilerden biri için ASP.NET Core Blazor form doğrulamasındaki yönergeleri izleyin:
- Etkileşimli işleme modunu benimseyen bir Blazor Web App içinde sunucu tarafı doğrulama.
- Tek başına Blazor Web Derlemesi uygulamasında istemci tarafı doğrulama.
- Yerel HTML doğrulama özniteliklerini kullanın (bkz . İstemci tarafı form doğrulaması (MDN belgeleri)).
- Üçüncü taraf doğrulama JavaScript kitaplığını benimseyin.
Sunucuda statik olarak işlenmiş formlar için, 2025'in sonlarında .NET 10 için istemci tarafı doğrulaması için yeni bir mekanizma dikkate alınmalıdır. Daha fazla bilgi için bkz . Bağlantı hattı olmadan kullanarak Blazor istemci doğrulaması ile sunucu tarafından işlenen formlar oluşturma (dotnet/aspnetcore
#51040).
Ek kaynaklar
- ASP.NET Core Blazor dosyası karşıya yüklemeleri
- Microsoft Entra ID ile barındırılan ASP.NET Core Blazor WebAssembly uygulamasının güvenliğini sağlama
- Azure Active Directory B2C ile barındırılan ASP.NET Core Blazor WebAssembly uygulamasının güvenliğini sağlama
- Sunucu ile Blazor WebAssembly barındırılan ASP.NET Core uygulamasının Identity güvenliğini sağlama
-
dotnet/blazor-samples
(nasıl indirilir) -
ASP.NET Core GitHub deposu (
dotnet/aspnetcore
) test varlıklarını oluşturur
ASP.NET Core