文章目录

  • 摘要
  • 动机
  • 基本原理
  • 详述
    • 钱包
    • Scrypt参数
    • 账户
    • 合约
  • 向后兼容性
  • 实现

摘要

本NEP描述了一个钱包标准用于钱包文件在NEO多种实现间的兼容。

动机

目前,不同的客户端程序生成不同的钱包文件。它们具有不同的文件格式,不同的存储方式以及不同的加密方式。用户很难在不同的客户端程序之间进行迁移,因为钱包文件的格式不同。尽管可以通过导出私钥来实现迁移,但是对于具有多个私钥的钱包来说是很麻烦的。我们需要一种通用钱包格式,允许用户安全轻松地跨所有平台迁移,而无需更改钱包文件或导出私钥。

基本原理

钱包标准应考虑安全性和跨平台兼容性。为了安全起见,我们要求实现使用NEP-2机制来加密或解密私钥。对于跨平台,我们使用JSON格式来描述钱包文件,以便可以在每个平台上轻松识别钱包文件的内容。

详述

钱包

Json格式的钱包文件具有以下的基础结构:

{
“name”: “MyWallet”,
“version”: “1.0”,
“scrypt”: {},
“accounts”: [],
“extra”: null
}

name是用户对钱包文件所做的标签。
version目前固定为1.0,将来用于功能性升级。
scrypt是一个ScryptParameters对象,用于描述钱包私钥加密解密用的SCrypt算法的参数。
accounts是一个Account对象数组,用于描述钱包中每个帐户的详细信息。
extra是由客户端的实现者定义,用于存储额外的数据。该字段可以为null。

Scrypt参数

ScryptParameters 对象具有一下结构:

{
“n”: 16384,
“r”: 8,
“p”: 8
}

n是定义CPU /内存开销的参数。必须是2 ^ N的值。
r是调整参数。
p是调整参数(并行参数)。大的p值可以在不增加内存使用量的情况下增加SCrypt的计算成本。

账户

账户对象具有以下结构:

{
“address”: “AQLASLtT6pWbThcSCYU1biVqhMnzhTgLFq”,
“label”: “MyAddress”,
“isDefault”: true,
“lock”: false,
“key”: “6PYWB8m1bCnu5bQkRUKAwbZp2BHNvQ3BQRLbpLdTuizpyLkQPSZbtZfoxx”,
“contract”: {},
“extra”: null
}

address 是账户的base58编码地址
label是用户对钱包做的标签
isDefault 代表账户是否是默认找零地址
lock表示帐户是否被用户锁定。客户端不能花费锁定帐户中的资金。
key是帐户私钥的NEP-2格式。此字段可以为空(仅限观察地址或非标准地址)。
contract是一个Contract对象,用于描述合约的细节。该字段可以为null(仅限监视地址)。
extra是由客户端的实现者定义的用于存储额外数据的对象。该字段可以为null。

合约

合约对象有以下结构:

{
“script”: “21036dc4bf8f0405dcf5d12a38487b359cb4bd693357a387d74fc438ffc7757948b0ac”,
“parameters”: [],
“deployed”: false
}

script是合约的脚本代码。如果合约已经被部署在区块链上,则该值可以为null。
parameters是参数对象数组,用于描述合约函数中每个参数的细节。需要更多参数对象的信息,可以查看NEP-3:NeoContractABI中的描述。

向后兼容性

所有旧格式的钱包必需可以轻易转换成这种新的JSON格式。如果这些钱包文件包含额外的数据,可以被存储在extra值中。

实现

• neo-project/neo: https://github.com/neo-project/neo/blob/master/neo/Implementations/Wallets/NEP6/NEP6Wallet.cs
• CityOfZion/neon-js: https://github.com/CityOfZion/neon-js/blob/master/src/wallet/Wallet.js

原文链接:https://github.com/neo-project/proposals/blob/master/nep-6.mediawiki

NEO改进协议提案6(NEP-6)相关推荐

  1. NEO改进协议提案1(NEP-1)

    文章目录 什么是NEP NEP基本原理 NEP类型 NEP工作流程 怎么才是一个合格的NEP NEP格式和模板 NEP序言 附件 NEP所有权转让 NEP编辑者 NEP编辑者的职责和工作流程 历史 什 ...

  2. NEO改进协议提案9(NEP-9)

    文章目录 摘要 动机 详述 原生资产转移URI URI键 可用URI 键 映射 NEO 交易属性键 参考原生资产地址 例子 智能合约调用URI NEP-5 token 转移 URI Keys 例子 原 ...

  3. NEO改进协议提案4(NEP-4)

    文章目录 摘要 动机 详述 neo neo-vm 智能合约示例 原理 向后兼容性 实现 摘要 此NEP提案概述了一种机制,通过该机制,智能合约能够调用直到运行时才知道的其他智能合约,而不仅限于调用在编 ...

  4. NEO改进协议提案7(NEP-7)

    文章目录 摘要 动机 原理 详述 鉴权触发器 鉴权R触发器 应用触发器 应用R触发器 后兼容性 实现 摘要 触发器是一种触发智能合约执行的机制.本NEP定义四种类型的触发器, 他们是鉴权触发器.鉴权R ...

  5. NEO改进协议提案5(NEP-5)

    文章目录 摘要 动机 详述 方法 totalSupply name symbol decimals balanceOf transfer 事件 transfer 实现 摘要 NEP-5提案概述了NEO ...

  6. NEO改进协议提案2(NEP-2)

    文章目录 摘要 动机 基本原理 详述 前缀 建议详述 加密步骤 解密步骤 向后兼容性 测试用例 实现 摘要 提出了一种以58字符 Base58Check编码的可打印字符串的形式对密码保密型私钥记录进行 ...

  7. NEO改进协议提案2(NEP-2) 1

    文章目录 摘要 动机 基本原理 详述 前缀 建议详述 加密步骤 解密步骤 向后兼容性 测试用例 实现 摘要 提出了一种以58字符 Base58Check编码的可打印字符串的形式对密码保密型私钥记录进行 ...

  8. 改进协议 BIP32-39-44概述

    BIP44 调研可行性调研 By Blake chen BIP 44 协议提出背景 签名算法是区块链系统中具有密码学属性的基础核心支撑算法.其资产确权.账户验证.身份确认.以及生成公私钥对进入区块链世 ...

  9. 【MORE协议】基于MORE的改进协议设计的MATLAB仿真

    0.完整源码获得方式 方式1:微信或者QQ联系博主 方式2:订阅MATLAB/FPGA教程,免费获得教程案例以及任意2份完整源码 1.软件版本 MATLAB2021a 2.本算法理论知识 随着无线通信 ...

最新文章

  1. 腾讯:我就是那只吃了假辣椒酱的憨憨。老干妈:企鹅你可长点心吧!
  2. 用javascript实现一门编程语言-字符输入流
  3. Angular中提示:Can't bind to 'ngModel' since it isn't a known property of 'input'
  4. Eclipse Git 克隆项目的时候出现Internal error; consult Eclipse error log
  5. 点云插值:三维平面参数确定-不共线三点的平面方程
  6. linux,apache,php,mysql常用的查看版本信息的方法
  7. 蜘蛛牌 HDU - 1584(搜索——达到先让某些段先结合,达最优解)
  8. 正则表达式加参数匹配
  9. 什么是多核电脑?什么是64位电脑?
  10. 架构师需要了解的知识
  11. xtragrid 某个值 查找_EXCEL查找引用函数:如果只推荐一个EXCEL函数,那就是这个了...
  12. .net core linux 串口,.Net Core 跨平台应用使用串口、串口通信 ,可能出现的问题、更简洁的实现方法...
  13. 2021年中国研究生数学建模竞赛B题参考思路
  14. 《金字塔原理》学习笔记
  15. 【翻译】Drafting and Revision: Laplacian Pyramid Network for Fast High-Quality Artistic Style Transfer
  16. 公众号添加跳转网页链接
  17. 小麦颗粒数目matlab,求关于matlab中rice.png图像中的米粒数目的算法
  18. R语言使用igraph包绘制网络图
  19. Unity3D连接本地或局域网MySQL数据库
  20. 因果森林总结:基于树模型的异质因果效应估计

热门文章

  1. 世界上最有用的100个网站
  2. 《健身入门学》第二课,肌肉生理生化基础(一)
  3. 传智播客前端开发_前端开发人员的最佳播客
  4. 寒假每日一题——和为 K 的最少斐波那契数字数目
  5. 中年人的职业规划,从来都不是自己一个人(选行业/公司/岗位……)的事儿...
  6. iptables指令逻辑详解
  7. 如何提取音频中的文字?音频文件如何转换成文字?
  8. 公务员计算机专业包括哪些专业,公务员计算机类及相关专业有哪些
  9. mms_ease-lite介绍
  10. AngelToken钱包——值得投资与存币的钱包