This sample app demonstrates how to use the built-in ASP.NET Core Identity capabilities from a standalone Blazor WebAssembly app.
For more information, see Secure ASP.NET Core Blazor WebAssembly with ASP.NET Core Identity.
-
Clone this repository or download a ZIP archive of the repository. For more information, see How to download a sample.
-
The default and fallback URLs for the two apps are:
Backend
app (BackendUrl
):https://localhost:7211
(fallback:https://localhost:5001
)BlazorWasmAuth
app (FrontendUrl
):https://localhost:7171
(fallback:https://localhost:5002
)
You can use the existing URLs or update them in the
appsettings.json
file of each project with newBackendUrl
andFrontendUrl
endpoints:appsettings.json
file in the root of theBackend
app.wwwroot/appsettings.json
file in theBlazorWasmAuth
app.
-
If you plan to run the apps using the .NET CLI with
dotnet run
, note that first launch profile in the launch settings file is used to run an app, which is the insecurehttp
profile (HTTP protocol). To run the apps securely (HTTPS protocol), take either of the following approaches:- Pass the launch profile option to the command when running the apps:
dotnet run -lp https
. - In the launch settings files (
Properties/launchSettings.json
) of both projects, rotate thehttps
profiles to the top, placing them above thehttp
profiles.
If you use Visual Studio to run the apps, Visual Studio automatically uses the
https
launch profile. No action is required to run the apps securely when using Visual Studio. - Pass the launch profile option to the command when running the apps:
-
Run the
Backend
andBlazorWasmAuth
apps. -
Navigate to the
BlazorWasmAuth
app at theFrontendUrl
. -
Register a new user using the Register link in the upper-right corner of the app's UI or use one of the preregistered test users:
[email protected]
(Password:Passw0rd!
). Leela hasAdministrator
,Manager
, andUser
roles and can access the private manager page but not the private editor page of the app. She can process data with both forms on the data processing page.[email protected]
(Password:Passw0rd!
). Harry only has theUser
role and can't access the manager and editor pages. He can only process data with the first form on the data processing page.
-
Log in with the user.
-
Navigate to the private page (
Components/Pages/PrivatePage.razor
at/private-page
) that only authenticated users can reach. A link to the page appears in the navigation sidebar after the user is authenticated. Navigate to the private manager and editor pages to explore how the user's roles influence the pages that they can visit. Navigate to the data processing page (Components/Pages/DataProcessing.razor
at/data-processing
) to experience authenticated and authorized data processing web API calls. -
Log out of the app.