区块链签名种类


1. eth_sign

  • 简介:最早实现的签名方法,用于对任意数据进行签名。
  • 签名内容:直接对原始消息的哈希值进行签名。
  • 特点
    • 安全性较低,因为签名的消息没有明确的上下文或结构。
    • 很容易被滥用,攻击者可以伪造签名内容。
  • 适用场景:早期应用,但不推荐用于重要场景。
  • 风险:容易被用作重放攻击,因此通常被认为是不安全的,这种千万不要用,应该被禁用。

2. personal_sign

  • 简介:改进的签名方法,专门为以太坊钱包实现。
  • 签名内容
    • 对消息前添加一个前缀("\x19Ethereum Signed Message:\n" + message.length),然后进行签名。
    • 这个前缀使得签名与交易签名区别开,防止重放攻击。
  • 特点
    • eth_sign 更安全。
    • 广泛用于钱包签名消息,例如用户登录验证。
  • 适用场景:个人签名、验证身份等。

3. signTypedData 和变体

这些方法用于签名结构化数据,与 EIP-712 标准相关联。它们允许对特定格式的复杂数据进行签名,提供更高的安全性和可读性。

signTypedData_v1
  • 简介:初始版本,实现较为简单。
  • 签名内容:签名 JSON 数据的字符串形式。
  • 特点
    • 签名的内容是字符串化后的数据,而不是结构化数据本身。
    • 可读性差,容易出错。
  • 状态:很少被使用,已被后续版本替代。
signTypedData_v3
  • 简介:基于 EIP-712 的第一个广泛实现版本。
  • 签名内容
    • 使用 EIP-712 定义的数据结构。
    • 签名前将数据结构编码为更紧凑和可读的形式。
  • 特点
    • 更安全,数据结构明确。
    • 兼容 MetaMask 等钱包,但 UI 提示可能不够友好。
  • 适用场景:签名复杂的结构化数据,例如智能合约交互。
signTypedData_v4
  • 简介:最新实现,完全符合 EIP-712 标准。
  • 签名内容
    • 支持更复杂的数据类型,例如数组和嵌套结构。
    • v3 更灵活和强大。
  • 特点
    • 用户在签名前可以更清楚地看到要签名的内容。
    • 广泛支持于现代钱包中。
  • 适用场景:高级用例,例如链上治理、DeFi 协议交互。

4. 核心区别总结

方法安全性签名内容主要用途状态
eth_sign较低原始消息哈希值早期签名,已不推荐不推荐
personal_sign较高添加前缀的消息哈希值身份验证、个人消息签名常用
signTypedData_v1中等JSON 字符串化数据结构化数据签名(初版)很少使用
signTypedData_v3EIP-712 数据结构结构化数据签名,智能合约交互常用(兼容性好)
signTypedData_v4最高完整 EIP-712 支持支持复杂数据类型的结构化签名最新、广泛支持

推荐使用

  • 身份验证、消息签名personal_sign
  • 智能合约交互、复杂数据签名signTypedData_v4(优先)或 v3

对于开发者,建议始终选择安全性较高的 signTypedData 系列方法,同时确保用户界面能清晰地展示签名内容,避免用户在不明情况下授权。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/888944.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

AI-安全-B站

1 需求 百度-林道正-《大模型合规探索》火山引擎-林泽韬-《大模型安全挑战与防护实践》Chamd5-bayuncao-《基于RAG的AI代码审计框架》德国电信咨询有限公司-杨麟-《AI在SOC中的应用发展》360-李亚青-《以模制模,大模型安全的解决之道》金晴云华-富吉祥-《安全大脑在…

基于BiLSTM-CRF的中文电子病历命名实体识别

声明:博客未经允许禁止抄袭转载。 前言 最近有粉丝在后台私信我能不能更一篇关于命名实体识别(NER,Named Entity Recognition)的经典模型BiLSTM-CRF的实战文章,前段时间有点忙所有一直没有更新,趁着最近有点空,满足一…

k8s 优雅监控jvm及dump heap的方案探讨

背景 k8s cluster 的健康检测失败会主动重启pod,而大部份情况下健康检测失败都是由full gc引起的。往往发生重启时已经没有条件dump heap排查full gc的原因。 如何监控 为了避免因健康检测失败而导致的pod重启,我们需要实施有效的监控策略,这…

TPM 2.0:安全固件的新标准

得益于可信计算组 ( TCG ) 推出的全新 TPM 2.0规范,联网设备可以更好地抵御网络攻击,并且不太可能受到错误的攻击。 制造商将可信平台模块 (TPM) 附加到设备上,以帮助用户和管理员验证其身份、生成和存储加密密钥以及确保平台完整性。 在 T…

ensp实验-vrrp多网关配置

一、交换机与路由的配置区别 1. 角色定义交换机: Master 或 Backup: 交换机通常作为 Master 或 Backup 设备参与 VRRP,负责在主设备故障时接替其工作。路由器: Master 或 Backup: 路由器同样可以作为 Master 或 Backup 设备…

黑盒测试方法

‌黑盒测试是一种软件测试方法,它通过向系统提供输入并检查输出结果来验证系统的功能是否符合需求。‌黑盒测试主要关注软件的功能性,而不是其内部结构或工作原理。以下是几种常见的黑盒测试顺序方法: 场景设计法‌: 通过模拟实际…

游戏引擎学习第38天

仓库: https://gitee.com/mrxiao_com/2d_game 回顾上次的内容。 我们之前讨论了将精灵放在屏幕上,但颜色错误的问题。问题最终查明是因为使用了一个调整工具,导致文件的字节顺序发生了变化。重新运行“image magic”工具对一些大图像进行重新处理后&am…

TDengine 新功能 复合主键

1. 简介 从 TDengine 3.3.0.0 版本之后,新增了复合主键的功能。 TDengine 原来的时间列是不允许有重复时间戳的,有了复合主键功能后,时间列即允许有重复,重复后的时间戳按紧跟其后第二列主键列的值来确定唯一性。 此功能的常用…

aws(学习笔记第十六课) 使用负载均衡器(ELB)解耦webserver以及输出ELB的日志到S3

aws(学习笔记第十六课) 使用负载均衡器(ELB)以及输出ELB的日志到S3 学习内容: 使用负载均衡器(ELB)解耦web server输出ELB的日志到S3 1. 使用负载均衡器(ELB) 全体架构 使用ELB(Elastic Load Balancer)能够解耦外部internet访问和web server之间的耦合&#xff0c…

深入理解C#的TCPIP通信机制

本文还有配套的精品资源,点击获取 简介:在分布式系统和实时数据交换应用中,C#作为一种现代面向对象编程语言,利用其***命名空间下的Socket类,提供强大的TCP/IP通信功能。本文将探讨C#中TCP/IP通信的基本概念、使用方…

M9484C VXG 矢量信号发生器- 110GHz-

M9484C VXG 矢量信号发生器 - 110GHz- M9484C VXG 是一款矢量信号发生器,在每个通道上提供 2.5 GHz 调制带宽,能够生成高达 54 GHz 的信号。 这款 VXG 矢量信号发生器可以组成经过校准和同步的全方位综合解决方案,帮助您更快测试下一代无线…

高项 - 项目管理原则与项目绩效域

个人总结,仅供参考,欢迎加好友一起讨论 博文更新参考时间点:2024-12 高项 - 章节与知识点汇总:点击跳转 文章目录 高项 - 项目管理原则与项目绩效域项目管理12条原则原则1:成为勤勉、尊重和关心他人的管家 (p202)原则…

仿真技术助力高尔夫球打破传统设计局限,实现球杆强大的功能

Altair近日宣布与业内领先的高尔夫装备制造商 Cleveland Golf 开展合作,以设计新款 HiBore XL 球杆。借助 Altair 先进的仿真与设计技术,Cleveland Golf 不断刷新高尔夫装备的行业标准,并在球杆产品设计方面实现突破。 Cleveland Golf 借助 A…

python字符串处理基础操作总结

1.去掉空格或者特殊符号 input_str.strip() #去掉所有空格 input_str.lstrip() #去掉左边空格 input_str.rstrip() #去掉右边空格 def print_hi():input_str 今天天气不错,风和日丽 out input_str.strip()print(input_str)print(out)if __name__ __main__:print…

阿里云PolarDB 如何进行数据恢复,文档总结

PolarDB不同场景下的恢复方式文档介绍: PolarDB在不同误操作场景下如何恢复数据_云原生数据库 PolarDB(PolarDB)-阿里云帮助中心 1. 不管误删的是表还是数据库,通过快照或者pitr的方式恢复到一个新的集群 全量恢复1 - 从备份集恢复: 如何从…

C#请求https提示未能为 SSL/TLS 安全通道建立信任关系

System.Net.WebException: 基础连接已经关闭: 未能为 SSL/TLS 安全通道建立信任关系 ,这个错误通常表明你的应用程序在尝试建立一个安全的 SSL/TLS 连接时遇到了问题。这通常是由于证书验证失败引起的。证书验证失败可能有几个原因: 证书不受信任&#…

Trimble X9三维激光扫描仪高效应对化工厂复杂管道扫描测绘挑战【沪敖3D】

化工安全关系到国计民生,近年来随着化工厂数字化改革不断推进,数字工厂逐步成为工厂安全管理的重要手段。而化工管道作为工厂设施的重要组成部分,由于其数量多、种类繁杂,一直是企业管理的重点和难点。 传统的化工管廊往往缺乏详…

日志基础示例python和c++

文章目录 0. 引言1. python2. c 0. 引言 本文主要记录python版本和c版本常用的日志基础示例。 1. python python版本常用的是logging库,结合colorlog库,可根据不同日志级别打印不同颜色的日志,为了便于分析问题,还添加了日志保…

【Linux】openssl version mismatch. built against 30000010, you have 30200020

错误:openssl version mismatch. built against 30000010, you have 30200020 这个错误通常是因为系统中安装了不同版本的 OpenSSL 库,导致程序在编译时使用了一个版本的 OpenSSL,而运行时却加载了另一个版本的库。根据错误信息,您…

智能码二维码的应用如何与其他技术(如物联网)结合,以提高电动工具行业的效率?

智能码二维码与物联网等技术的结合,能够多方面提高电动工具行业的效率,以下是详细介绍: 生产管理环节 与物联网传感器结合实现生产数据实时采集:在电动工具生产线上,为生产设备安装物联网传感器,并将传感器…