I am playing with Blazor and created a web app that is server hosted. I have to put an authorize line on top of the page like this @attribute [Authorize] to ensure the user is logged in.
It seems like I have to add this line to each page individually. Is there a global setting that protects ALL the pages in the app, except for the login page of course.
Thanks!
To create a new Blazor WebAssembly project with an authentication mechanism: After choosing the Blazor WebAssembly App template in the Create a new ASP.NET Core Web Application dialog, select Change under Authentication. Select Individual User Accounts to use ASP.NET Core's Identity system.
CascadingAuthenticationState Component It's responsible for providing the current authentication state to it's decendent components. Currently this value is used by the Router and AuthorizeView components to control access to various parts of the UI.
I believe that will work... Place the following code snippet in the _Imports.razor file
@using Microsoft.AspNetCore.Authorization
@attribute [Authorize]
In that case, when the Index page is hit, the user will be redirected to the Login page. If you want to perform authentication before the Blazor App is being render, add the code snippet from above in the _Host.cshtml file
Add the @attribute [AllowAnonymous]
to specific pages you want to exculde from authentication, as for instance, the Index page.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With