在Blazor实现微信小程序扫码登录
在Blazor实现微信小程序扫码登录
——使用极简登录模型
最近需要开发一个Blazor Server Side页面,需要用到登录功能,作为某微信小程序的后管。在网上搜了一遍,似乎没有找到合适的,所以就自己造了个轮子。几乎都是代码,从来不需要写注释的我。
- 本文示例后端代码在
.NET 6
,下用Minimal Api
实现。 - 我是CHARSET,转载请保留全文本。
1. Blazor前端显示二维码
在GitHub
上随便找了个组件,名字是BlazorZXingJs
。使用方法也非常简单。将组件放入<NotAuthorized>
标签内部。
<QRCodeWriter Text="@Code" Width="200" Heigth="200" @ref="writer" />
如果需要每隔一段时间生成,则更换Code
的值即可。
2. 使用SignalR将ConnectionId从后端传给Blazor前端
在后端SignalR.Hub接受每次连接时传回
public override async Task OnConnectedAsync() {
await Clients.Caller.SendAsync("ConnectionId", Context.ConnectionId);
await base.OnConnectedAsync();
}
Blazor前端接收到ConnectionId
hubConnection.On<string>("ConnectionId", id => connectionId = id);
需要注意到的是,Blazor前端在收到此Id后才显示二维码
if (!string.IsNullOrEmpty(connectionId)) {
code = Guid.NewGuid().ToString();
Membership.RegisterScanCode(code);
Code = $"{code}|{connectionId}";
InvokeAsync(StateHasChanged);
}
为了简单起见,Code
使用上述逻辑生成。图像识别的结果是注册的二维码Code
和connectionId
。
3. 小程序解析快速响应码(QRCode)
function OnQRLogin() {
wx.scanCode({ onlyFromCamera: true, scanType: ['qrCode'],
success: function (res) {
const split = res.result.split('|')
wx.request({
url: `${host}/e/${token}/${split[0]}/${split[1]}`,
success: function (rt) {
if (rt.data && rt.data.success) {
wx.showModal({ title: '成功', content: '请注意登录页面是否成功的信息', icon: 'success' })
}
}
})
}
})
}
4. 后端服务根据ConnectionId将Token和二维码Code回送给Blazor前端
application.MapGet("/e/{token}/{recog}/{cid}", async Task<SimpleResponse>
(string token, string recog, string cid, [FromServices] ChatHubHelper hub) => {
var response = new SimpleResponse();
await hub.SendRequest(cid, new LoginRequest { ScanCode = recog, Token = token });
response.Success = true;
return response;
});
5. Blazor前端收到此回执后正常使用极简模型登录
hubConnection.On<LoginRequest>("LoginRequest", async request => {
connectionId = "已扫描,请静待结果……";
var response = await AuthStateProvider.Login(request);
if (response.Success) {
Membership.UnRegisterScanCode(code);
await Message.Success("登录成功");
} else {
await Message.Warn(response.Message);
}
await InvokeAsync(StateHasChanged);
});
初版在2022年3月17日写
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· .NET10 - 预览版1新功能体验(一)