首页
/ Blockscout项目中的统一认证签名机制优化

Blockscout项目中的统一认证签名机制优化

2025-06-17 19:45:47作者:宗隆裙

背景介绍

在区块链浏览器Blockscout的生态系统中,用户认证是一个核心功能。项目团队近期对认证流程进行了优化,旨在实现一个签名同时服务于两个认证服务:Merits系统和Blockscout账户系统。

技术实现方案

原有流程的问题

在优化前,用户需要分别生成两个不同的签名来访问Merits和账户系统,这不仅增加了用户操作复杂度,也影响了用户体验。

统一认证机制

新方案通过以下技术改进实现了统一认证:

  1. 配置检测:首先检查Merits服务的配置端点,确认是否支持共享登录功能。当<merits_url>/api/v1/config返回的JSON中包含"shared_siwe_login": true时,表示系统支持统一认证。

  2. 简化API调用:合并了原有的两个API调用流程,现在只需向Merits服务发送一个请求即可获取所有必要的认证信息。

  3. 响应数据结构:API响应现在包含两个nonce值:

    • nonce:用于Blockscout账户认证
    • merits_login_nonce:专用于Merits系统认证

签名消息格式

统一后的签名消息包含了两个系统的认证信息,格式示例如下:

eth.blockscout.com wants you to sign in with your Ethereum account: <address>

Sign in/up to Blockscout Account V2 & Blockscout Merits program.[ Referral code: BSCOUT][ Merits nonce: trCGuP0OqkrahmW2Y]

URI: https://eth.blockscout.com
Version: 1
Chain ID: 1
Nonce: cCUiCPh6DFG
Issued At: 2025-01-20T11:14:37.513Z
Expiration Time: 2026-01-20T11:14:37.513Z

技术优势

  1. 用户体验提升:用户只需进行一次签名操作,即可访问两个系统。

  2. 安全性保持:虽然认证流程简化,但安全性并未降低,每个系统仍使用独立的nonce值。

  3. 向后兼容:通过配置开关控制功能启用,确保与旧版本兼容。

  4. 可扩展性:该架构设计便于未来集成更多需要认证的服务。

实现状态

根据项目进展,这一优化方案已经完成开发并部署到生产环境。开发团队通过合理的API设计和消息格式定义,成功实现了认证流程的简化,同时保持了系统的安全性和可靠性。

这一改进体现了Blockscout项目对用户体验的持续关注和技术架构的不断优化,为区块链浏览器生态系统的进一步发展奠定了坚实基础。

登录后查看全文
热门项目推荐

热门内容推荐

最新内容推荐

项目优选

收起
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
178
262
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
868
513
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
129
183
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
268
308
HarmonyOS-ExamplesHarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
398
373
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.07 K
0
ShopXO开源商城ShopXO开源商城
🔥🔥🔥ShopXO企业级免费开源商城系统,可视化DIY拖拽装修、包含PC、H5、多端小程序(微信+支付宝+百度+头条&抖音+QQ+快手)、APP、多仓库、多商户、多门店、IM客服、进销存,遵循MIT开源协议发布、基于ThinkPHP8框架研发
JavaScript
93
15
note-gennote-gen
一款跨平台的 Markdown AI 笔记软件,致力于使用 AI 建立记录和写作的桥梁。
TSX
83
4
cherry-studiocherry-studio
🍒 Cherry Studio 是一款支持多个 LLM 提供商的桌面客户端
TypeScript
599
58
GitNextGitNext
基于可以运行在OpenHarmony的git,提供git客户端操作能力
ArkTS
10
3