Dapper在Blazor WebAssembly中怎么用 Dapper与Blazor WASM

来源:这里教程网 时间:2026-02-21 17:33:07 作者:

不能直接在Blazor WebAssembly中用Dapper访问数据库。

这是关键前提——Dapper是一个.NET数据库访问库,依赖

IDbConnection
(如
SqlConnection
),而这些类型在WebAssembly运行时不可用,也无法建立到SQL Server、MySQL等后端数据库的直连。浏览器环境不支持TCP socket或本地数据库驱动,所有数据访问必须走HTTP API。

为什么Dapper不能在WASM客户端执行SQL

Dapper需要:

.NET数据库提供程序(如
Microsoft.Data.SqlClient
)——它们在WASM中不支持且无法加载
真实的数据库连接(
SqlConnection
等)——浏览器无权限创建底层网络连接
同步/异步I/O原语(如
Socket
)——WASM沙箱禁止此类操作

正确使用方式:Dapper放在API服务端

典型架构是“Blazor WASM(前端)→ ASP.NET Core Web API(后端)→ Dapper(数据层)”:

在ASP.NET Core服务器项目中安装Dapper:
dotnet add package Dapper
用Dapper封装仓储逻辑,例如
UserRepository.GetUsersAsync()
通过REST接口暴露为
GET /api/users
等端点
Blazor组件用
HttpClient
调用该API,接收JSON,不接触SQL或连接字符串

Blazor组件里能做什么(替代方案)

虽然不能用Dapper,但可以高效处理返回的数据:

System.Text.Json
Newtonsoft.Json
反序列化API响应
配合
@inject HttpClient Http
发起请求,例如:
var users = await Http.GetFromJsonAsync<list>>("api/users");</list>
对本地数据做内存查询(如Linq to Objects)——适合缓存后筛选、排序 如需轻量级本地存储,可用IndexedDB(通过JS Interop)或
localStorage
,但不是Dapper的替代品

常见误解与提醒

有人尝试用

SqlitePCLRaw
或WASM版SQLite——这仅适用于纯本地文件数据库(无服务端交互),且Dapper仍无法适配其连接对象;官方也不支持。真正生产级应用必须走服务端Dapper + HTTP通信。

基本上就这些。绕过HTTP直接让WASM跑Dapper,技术上行不通,也不符合现代Web安全模型。

相关推荐