翼度科技»论坛 编程开发 .net 查看内容

学习ASP.NET Core Blazor编程系列二十六——登录(5)

5

主题

5

帖子

15

积分

新手上路

Rank: 1

积分
15
学习ASP.NET Core Blazor编程系列文章之目录学习ASP.NET Core Blazor编程系列一——综述学习ASP.NET Core Blazor编程系列二——第一个Blazor应用程序(上)
学习ASP.NET Core Blazor编程系列三——实体学习ASP.NET Core Blazor编程系列五——列表页面学习ASP.NET Core Blazor编程系列七——新增图书学习ASP.NET Core Blazor编程系列八——数据校验学习ASP.NET Core Blazor编程系列十三——路由(完)学习ASP.NET Core Blazor编程系列十五——查询学习ASP.NET Core Blazor编程系列十六——排序学习ASP.NET Core Blazor编程系列二十——文件上传(完)学习ASP.NET Core Blazor编程系列二十一——数据刷新 学习ASP.NET Core Blazor编程系列二十二——登录(1) 九、模拟登录

     登录的本质原理同网页应用是一样的,一般的流程是:

      用户打开登页--》输入账号密码后提交表单--》服务端验证成功后生成cookie信息写入浏览器--》之后用户访问页面时浏览器会带上此cookie信息作为用户标识--》服务端解析此cookie信息就能识别这个用户了。

      在webapi出现之后,出现了JWT这样的认证方式,原理大同小异,相同的是, 认证信息都是保存在请求头中传递的,不同是JWT中的认证信息需要编码写入请求头之后再发送请求,不像浏览器,发送请求时会自动带上cookie信息,不需要编码。

Blazor中的登录流程可以分成几下几个步骤:


  • 启用验证
  • 制作自定义AuthenticationStateProvider
  • 修改App.razor
  • 使用AuthorizeView和进行登录验证和角色授权
自定义AuthenticationStateProvider

       首先来理解一下什么是AuthenticationStateProvider。AuthenticationStateProvider是一个抽象类,由Microsoft.AspNetCore.Components.Authorization类库提供,主要用来提供当前用户的认证状态信息。既然是抽象类,我们需要自定义一个它的子类,由于是模拟登录,进行登录流程的验证,因此我们先来做一个测试的Provider来试试。

1. 在Visual Studio 2022的解决方案资源管理器中,在项目名称“BlazorAppDemo”上单击鼠标右键,在弹出菜单中选择“添加—>新建文件夹”,并将之命名为“Auth”。如下图。


 
2. 在Visual Studio 2022的解决方案资源管理器中,鼠标左键选中“Auth”文件夹,右键单击,在弹出菜单中选择“添加—>类”,并将类命名为“ImitateAuthStateProvider”。 AuthStateProvider类的最核心方法是 Task GetAuthenticationStateAsync()。基于最简单的登录机制,我们的扩展提供程序如下。具体代码如下:
  1. using BlazorAppDemo.Models;
  2. using Microsoft.AspNetCore.Components.Authorization;
  3. using System.Security.Claims;
  4. namespace BlazorAppDemo.Auth
  5. {
  6.     public class ImitateAuthStateProvider : AuthenticationStateProvider
  7.     {
  8.         bool isLogin = false;
  9.         public override Task<AuthenticationState> GetAuthenticationStateAsync()
  10.         {
  11.             if (isLogin)
  12.             {
  13.                 var claims = new List<Claim>()
  14.             {
  15.                 new Claim(ClaimTypes.Name,"user"),
  16.                 new Claim(ClaimTypes.Role, "admin")
  17.             };
  18.                 var anonymous = new ClaimsIdentity(claims, "testAuthType");
  19.                 return Task.FromResult(new AuthenticationState(new ClaimsPrincipal(anonymous)));
  20.             }
  21.             else
  22.             {
  23.             var anonymous = new ClaimsIdentity();
  24.             return Task.FromResult(new AuthenticationState(new ClaimsPrincipal(anonymous)));
  25.         }
  26.         }
  27.         public void Login(UserInfo request)
  28.         {
  29.             if (request.UserName == "user" && request.Password == "111111")
  30.                 isLogin = true;   
  31.             NotifyAuthenticationStateChanged(GetAuthenticationStateAsync());
  32.            
  33.       
  34.         }
  35.     }
  36. }
复制代码
ImitateAuthStateProvider继承AuthenticationStateProvider,并重写GetAuthenticationStateAsync方法。

  • var anonymous = new ClaimsIdentity();:我们现在进行模拟登录,先做一个匿名的使用者,所以ClaimsIdentity的构造方法中不传参数。
  • 返回AuthenticationState。
  • 我们给ClaimsIdentity一个List属性,其中有使用者的名字和角色,表示我们已登录成功。
3. 在Visual Studio 2022的解决方案资源管理器中,使用鼠标双击在文本编辑器中打开Program.cs文件,使用
  1. builder.Services.AddScoped<ImitateAuthStateProvider>();
  2. builder.Services.AddScoped<AuthenticationStateProvider>(implementationFactory =>
  3. implementationFactory.GetRequiredService<ImitateAuthStateProvider>());
复制代码
;这二行代码使用DI方式注入ImitateAuthStateProvider。具体代码如下:

 
  1. using BlazorAppDemo.Data;using BlazorAppDemo.Models;using Microsoft.AspNetCore.Components;using Microsoft.AspNetCore.Components.Web;using Microsoft.Extensions.Configuration;using Microsoft.EntityFrameworkCore;using Microsoft.Extensions.Hosting;using Microsoft.AspNetCore.Components.Authorization;using BlazorAppDemo.Auth;var builder = WebApplication.CreateBuilder(args);// Add services to the container.builder.Services.AddRazorPages();builder.Services.AddServerSideBlazor();builder.Services.AddSingleton();System.Console.WriteLine(ConfigHelper.Configuration["ConnectionStrings:BookContext"]);builder.Services.AddDbContextFactory(opt =>    opt.UseSqlServer(ConfigHelper.Configuration["ConnectionStrings:BookContext"]));//builder.Services.AddScoped();builder.Services.AddScoped<ImitateAuthStateProvider>();
  2. builder.Services.AddScoped<AuthenticationStateProvider>(implementationFactory =>
  3. implementationFactory.GetRequiredService<ImitateAuthStateProvider>());  var app = builder.Build(); // Configure the HTTP request pipeline.if (!app.Environment.IsDevelopment()){    app.UseExceptionHandler("/Error");    // The default HSTS value is 30 days. You may want to change this for production scenarios, see https://aka.ms/aspnetcore-hsts.    app.UseHsts();}  using (var scope = app.Services.CreateScope()){    var services = scope.ServiceProvider;    try    {        Console.WriteLine("数据库开始初始化。");        var context = services.GetRequiredService();        // requires using Microsoft.EntityFrameworkCore;        context.Database.Migrate();        // Requires using RazorPagesMovie.Models;        SeedData.Initialize(services);        Console.WriteLine("数据库初始化结束。");    }     catch (Exception ex)    {        var logger = services.GetRequiredService();        logger.LogError(ex, "数据库数据初始化错误.");    }} app.UseHttpsRedirection();app.UseStaticFiles();app.UseRouting(); app.MapBlazorHub();app.MapFallbackToPage("/_Host");app.Run();
复制代码
修改App.razor

现在我们已经完成了登录认证的Provider了,接下來要做的事情,就是让我们的页面上的组件,可以获取登录信息,来决定是登录用户是否已经授权。这一步请参数之前的文章学习ASP.NET Core Blazor编程系列二十三——登录(3)之中的“七、修改路由与启动页面”。

修改Login.razor页面进行登录

在Visual Studio 2022的文本编辑器中打开Login.razor组件文件,我们将鼠标定位到@code中的SubmitHandler方法 ,写上我们登录成功的代码。具体代码如下:  
  1. @page "/Login"
  2. @using BlazorAppDemo.Auth;
  3. @using BlazorAppDemo.Models
  4. @using BlazorAppDemo.Utils
  5. @layout LoginLayout
  6. @inject NavigationManager NavigationManager
  7. @inject ImitateAuthStateProvider AuthStateProvider;
  8.    
  9.         <h3>Login</h3>
  10.         <hr />
  11.         <EditForm  Model="loginModel" OnValidSubmit="SubmitHandler" OnInvalidSubmit="InvalidHandler">
  12.             <DataAnnotationsValidator />
  13.            
  14.             
  15.                 <label for="userName">  @HtmlHelper.GetDisplayName(loginModel ,m=> m.UserName)</label>
  16.                 <InputText @bind-Value="loginModel.UserName" class="form-control" id="userName" />
  17.                 <ValidationMessage For="()=>loginModel.UserName" />
  18.             
  19.             
  20.                 <label for="pwd"> @HtmlHelper.GetDisplayName(loginModel ,m=> m.Password)</label>
  21.                 <InputPassword @bind-Value="loginModel.Password" class="form-control" id="pwd" />
  22.                 <ValidationMessage For="()=>loginModel.Password" />
  23.             
  24.             <span class="form-control-plaintext"></span>
  25.             
  26.                
  27.             <button class="btn btn-primary">登录</button>
  28.                
  29.             
  30.         </EditForm>
  31.    
  32. @code {
  33.     private UserInfo loginModel = new UserInfo();
  34.     bool isAuthLoading = false;
  35.     private void SubmitHandler()
  36.     {
  37.         Console.WriteLine($"用户名:{loginModel.UserName} ,密码:{loginModel.Password}");
  38.          isAuthLoading = true;
  39.     try {
  40.          AuthStateProvider.Login(new UserInfo() {
  41.                     UserName = loginModel.UserName,
  42.                     Password =loginModel.Password
  43.         });
  44.             NavigationManager.NavigateTo("/Index");
  45.     } catch (Exception ex) {
  46.          Console.WriteLine(ex.Message);
  47.     } finally {
  48.         isAuthLoading = false;
  49.     }
  50.     }
  51.     private void InvalidHandler()
  52.     {
  53.         Console.WriteLine($"用户名: {loginModel.UserName} ,密码:{loginModel.Password}");
  54.     }
  55. }
复制代码
 
登录并显示当前用户

1.在Visual Studio 2022的文本编辑器中打开MainLayout.razor组件文件,在AuthorizeView中显示当前登录用户,具体代码如下:

2.在Visual Studio 2022的菜单栏上,找到“调试-->开始调试”或是按F5键,Visual Studio 2022会生成BlazorAppDemo应用程序,浏览器中会Login登录页面。
  1. @using BlazorAppDemo.Pages
  2. @inherits LayoutComponentBase
  3. <PageTitle>BlazorAppDemo</PageTitle>
  4.    
  5.         <NavMenu />
  6.    
  7.     <main>
  8.         <AuthorizeView>
  9.             <Authorized>
  10.               
  11.             <a href="https://docs.microsoft.com/aspnet/" target="_blank">About</a>
  12.             <p>
  13.        你好, @context.User.Identity.Name!
  14.       </p>
  15.          
  16.         <article class="content px-4">
  17.                     @Body
  18.         </article>
  19.             </Authorized>
  20.             <NotAuthorized>
  21.                
  22.                     <span style="font-size:20px">检测到登录超时,请重新<a target="_blank" href="https://www.cnblogs.com/login" style="text-decoration:underline">登录</a>!<br><br></span>
  23.                
  24.                 <RedirectToLogin></RedirectToLogin>
  25.             </NotAuthorized>
  26.         </AuthorizeView>      
  27.     </main>
  28.  
复制代码
3.我们在用户名输入框中输入用户名,在密码输入框中输入密码,点击“登录”按钮,进行模拟登录。我们进入了系统。如下图。

 
     到此为止,我们已经实现了Blazor的登录认证流程,接下来我们要来实现通过jwt进行登录。


来源:https://www.cnblogs.com/chillsrc/archive/2023/02/19/17135448.html
免责声明:由于采集信息均来自互联网,如果侵犯了您的权益,请联系我们【E-Mail:cb@itdo.tech】 我们会及时删除侵权内容,谢谢合作!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x

举报 回复 使用道具