0

0

Blazor LocalStorage 和 SessionStorage 使用方法

幻夢星雲

幻夢星雲

发布时间:2025-12-23 00:05:37

|

621人浏览过

|

来源于php中文网

原创

Blazor中LocalStorage/SessionStorage使用分三种:Blazor Server用ProtectedBrowserStorage(自动加密、仅LocalStorage);WebAssembly推荐Blazored.LocalStorage(支持两者、泛型序列化);轻量需求可手写JS互操作。

blazor localstorage 和 sessionstorage 使用方法

Blazor 中使用 LocalStorage 和 SessionStorage 很简单,核心是借助 Microsoft.JSInterop 调用浏览器原生 API。.NET 6+ 官方已提供轻量封装(Microsoft.AspNetCore.Components.Server.ProtectedBrowserStorage),但要注意它只适用于 Blazor Server,且默认加密;而 Blazor WebAssembly 需自行封装 JS 互操作或使用社区库(如 Blazored.LocalStorage)。

Blazor Server:用 ProtectedBrowserStorage(自动加密)

这是微软为 Blazor Server 提供的内置方案,数据存入浏览器 LocalStorage 但会自动加密,适合存敏感度中等的信息(如用户偏好、临时 token)。它不支持 SessionStorage,仅 LocalStorage。

  • Program.cs(.NET 6+)中注册服务:
    builder.Services.AddProtectedBrowserStorage();
  • 在组件中注入并使用:
    @inject ProtectedLocalStorage Storage
    读取:var value = await Storage.GetAsync("key");
    写入:await Storage.SetAsync("key", "value");
    删除:await Storage.DeleteAsync("key");
  • 注意:该服务依赖服务器端密钥保护,不能跨不同 Blazor Server 实例共享密钥,也不适用于 WebAssembly。

Blazor WebAssembly:推荐 Blazored.LocalStorage

这是最主流、维护活跃的第三方库,同时支持 LocalStorage 和 SessionStorage,API 清晰,且兼容 .NET 5/6/7/8。

  • 安装 NuGet 包:Blazored.LocalStorage
  • Program.cs 注册:
    builder.Services.AddBlazoredLocalStorage();(加在 AddWasmHostedServices() 后)
  • 组件中使用:
    @inject ILocalStorageService LocalStorage
    @inject ISessionStorageService SessionStorage

    存值:await LocalStorage.SetItemAsStringAsync("theme", "dark");
    取值:var theme = await LocalStorage.GetItemAsStringAsync("theme");
    同理替换 LocalStorageSessionStorage 即可操作会话级存储
  • 支持泛型序列化(自动 JSON 序列化对象),也提供同步方法(如 SetItemAsString 不带 Async 后缀,但不推荐在主线程阻塞调用)。

手动 JS 互操作(通用,适合轻量需求)

如果不想引入额外包,可手写 JS 函数 + C# 调用。适用于两种托管模型,但需自行处理序列化和错误。

95Shop仿醉品商城
95Shop仿醉品商城

95Shop可以免费下载使用,是一款仿醉品商城网店系统,内置SEO优化,具有模块丰富、管理简洁直观,操作易用等特点,系统功能完整,运行速度较快,采用ASP.NET(C#)技术开发,配合SQL Serve2000数据库存储数据,运行环境为微软ASP.NET 2.0。95Shop官方网站定期开发新功能和维护升级。可以放心使用! 安装运行方法 1、下载软件压缩包; 2、将下载的软件压缩包解压缩,得到we

下载
  • wwwroot/index.html(WASM)或 Pages/_Host.cshtml(Server)的 中添加:
  • window.store = {
    saveL: (key, data) => localStorage.setItem(key, data),
    loadL: (key) => localStorage.getItem(key),
    saveS: (key, data) => sessionStorage.setItem(key, data),
    loadS: (key) => sessionStorage.getItem(key)
    };
  • C# 中调用(例如在组件里):
    @inject IJSRuntime JSRuntime
    await JSRuntime.InvokeVoidAsync("store.saveL", "counter", "42");
    var val = await JSRuntime.InvokeAsync("store.loadL", "counter");
  • 注意:传对象时需先 JsonSerializer.Serialize,取值后要 JsonSerializer.Deserialize;建议加 try-catch 处理浏览器禁用存储的情况。

注意事项与最佳实践

无论哪种方式,都要留意浏览器限制和用户体验边界。

  • 大小限制:通常 5–10 MB,超出会抛 QuotaExceededError,建议写入前检查或降级处理(如只存 ID,数据放后端
  • 同源策略:LocalStorage/SessionStorage 严格按协议+域名+端口隔离,localhost:5000 和 localhost:5001 互不可见
  • 隐私模式:部分浏览器在无痕窗口中可能禁用或清空存储,需有 fallback 逻辑(如默认值)
  • 敏感信息:不要存密码、完整 token(尤其是 refresh token);LocalStorage 比 SessionStorage 更不安全(持久存在,易被 XSS 窃取)
  • 响应式更新:原生存储变更不会通知 Blazor 组件重绘,如需监听变化,可用 window.addEventListener('storage', ...) 手动触发 StateHasChanged()

基本上就这些。选方案时优先考虑项目类型:Server 用 ProtectedBrowserStorage 省心;WebAssembly 直接上 Blazored.LocalStorage;极简场景或教学演示可手写 JS 互操作。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

411

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

532

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

309

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

74

2025.09.10

html版权符号
html版权符号

html版权符号是“©”,可以在html源文件中直接输入或者从word中复制粘贴过来,php中文网还为大家带来html的相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

609

2023.06.14

html在线编辑器
html在线编辑器

html在线编辑器是用于在线编辑的工具,编辑的内容是基于HTML的文档。它经常被应用于留言板留言、论坛发贴、Blog编写日志或等需要用户输入普通HTML的地方,是Web应用的常用模块之一。php中文网为大家带来了html在线编辑器的相关教程、以及相关文章等内容,供大家免费下载使用。

646

2023.06.21

html网页制作
html网页制作

html网页制作是指使用超文本标记语言来设计和创建网页的过程,html是一种标记语言,它使用标记来描述文档结构和语义,并定义了网页中的各种元素和内容的呈现方式。本专题为大家提供html网页制作的相关的文章、下载、课程内容,供大家免费下载体验。

466

2023.07.31

html空格
html空格

html空格是一种用于在网页中添加间隔和对齐文本的特殊字符,被用于在网页中插入额外的空间,以改变元素之间的排列和对齐方式。本专题为大家提供html空格的相关的文章、下载、课程内容,供大家免费下载体验。

245

2023.08.01

Golang gRPC 服务开发与Protobuf实战
Golang gRPC 服务开发与Protobuf实战

本专题系统讲解 Golang 在 gRPC 服务开发中的完整实践,涵盖 Protobuf 定义与代码生成、gRPC 服务端与客户端实现、流式 RPC(Unary/Server/Client/Bidirectional)、错误处理、拦截器、中间件以及与 HTTP/REST 的对接方案。通过实际案例,帮助学习者掌握 使用 Go 构建高性能、强类型、可扩展的 RPC 服务体系,适用于微服务与内部系统通信场景。

6

2026.01.15

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Bootstrap 5教程
Bootstrap 5教程

共46课时 | 2.9万人学习

AngularJS教程
AngularJS教程

共24课时 | 2.6万人学习

CSS教程
CSS教程

共754课时 | 19.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号