Hi 游客

更多精彩,请登录!

比特池塘 区块链技术 正文

NEP-6钱包标准

哈哈笑417
189 0 0
NEP:NEO Enhancement Proposals,即NEO改进提案,描述了NEO平台的标准,包括核心协议规范,客户端API和合约标准等。最为熟知的是NEP-5代币标准。' {4 ]( a! Y4 O& N+ Q
目前NEP-6钱包标准已经完成,以下为NEP-6钱包标准的Github文档(https://github.com/neo-project/proposals/blob/master/nep-6.mediawiki3 I, d# c/ s7 H3 Q
摘要# j# {& y8 D; e" X$ k) u
NEP-6描述了一个钱包标准,将支持钱包文件在NEO的各种钱包客户端之间共享。
! Q) S6 b; N4 U% E目标, S' s' a1 p8 ^7 }1 X4 M: l3 K
目前,不同的客户端程序会生成不同的钱包文件。他们有不同的文件格式,不同的存储方式,以及不同的加密方式。用户难以在不同的客户端程序之间迁移,因为钱包文件格式不同。尽管可以通过导出私钥来实现移植,但是对于具有多个私钥的钱包而言,这是非常麻烦的。我们需要一个通用的钱包格式,允许用户安全而轻松地迁移到所有平台上,而无需更改钱包文件或导出私钥。
) y( W9 R, _' G1 R* N4 U基本原理# ~; i9 N' W# ^6 J; ]
钱包标准应该考虑安全性和跨平台兼容性。为了安全起见,我们要求实现使用NEP-2(https://github.com/neo-project/proposals/blob/master/nep-2.mediawiki)机制来加密或解密私钥。为了达成跨平台要求,我们使用JSON格式来描述钱包文件,以便在每个平台上能够识别钱包文件的内容。$ H: s* H" P# J6 y! H
规范
$ D$ b. [. x6 zJSON格式的钱包文件由以下内容构成基本结构
9 S! v! h5 U& n6 I- J" _4 m% e{
3 l* S: R( M$ Y2 j9 r  "name": "MyWallet",
: G8 E7 ?5 H$ ~- {3 g' P! Z  "version": "1.0",; ^1 J8 z+ P: j% [, |
  "scrypt": {},
5 O7 E0 A5 n6 u0 v4 o  "accounts": [],
4 _! F1 {6 I; k+ R, Q$ Y4 |$ }  "extra": null
) A8 j5 k' s8 G}
; h% N3 p( X0 t& J. Gname 是用户对钱包文件所做的标记。
! x( q- ^/ `$ H! eversion目前已经修复1.0并将用于未来的功能升级。
: W( i3 i" @/ y% z* [: d, Sscrypt 是一个ScryptParameters对象,它描述了用于加密和解密钱包中私钥的SCrypt算法的参数。* u) s, a4 p1 T! i# e$ G) q, @1 S
accounts 是一个Account对象的数组,用于描述钱包中每个账户的详细信息。
6 O9 h3 z, _' q2 _1 N8 C- ?extra 是由客户的实现者定义的用于存储额外数据的对象。这个字段可以null。
' s5 C6 y% |; m: C/ S/ Z7 N; uScryptParameters0 B$ _# [& f: y- N# U$ P5 A
ScryptParameters对象具有以下结构:
  b( e1 Q) P9 G# k7 v" a{% o# D3 R5 x  X$ Z# J3 ?  Q- i6 _
  “n”:16384,
9 L$ n6 H$ i* C/ j  p" H* T5 \  “r”:8,( B1 l! Y4 ?# J/ d8 x% S0 `+ J6 [5 @' ~
  “p”:8}2 J. d' e( t  A: d0 k) t1 }1 C
n是定义CPU /内存成本的参数。必须是2 ^ N的值。# l; A. [0 l/ C9 q/ x. `
r 是一个调整参数。' j3 _* g/ Z& J8 @( K- R: S
p是一个调整参数(并行参数)。大的p值会增加SCrypt的计算成本,而不会增加内存使用量。  i# u4 ]( J5 N" N' Q( q
账户* u& |( g/ N& W$ ^+ k# M- D( K
账户对象具有以下结构:
: I$ {  `( t" q/ _+ L{
" _6 `9 S( w: {# ]  “address”:“AQLASLtT6pWbThcSCYU1biVqhMnzhTgLFq”,; D( f. g/ U' H2 G
  “label”:“MyAddress”,$ j: Y" |* o  E
  “isDefault”:true,
$ c" w0 V* |! ]1 m$ I* Z( g  “lock”:false,6 p* |) a% l" _5 D6 F) A0 L
  “key”:“6PYWB8m1bCnu5bQkRUKAwbZp2BHNvQ3BQRLbpLdTuizpyLkQPSZbtZfoxx”,; ~3 C$ L6 \' I5 z! d8 ?
  “contract”:{},
* Q( A6 A: V: j" L# I  “extra”:null}. n  F, i$ E; s$ f* `4 R- J
address 是帐户的base58编码地址。. J! \: Y- n! B' \! J
label 是用户对帐户所做的标签。' I' A! \! ^' r- V: [
isDefault 指示该帐户是否是默认的更改帐户。9 K) B) K8 U' |) r0 D( D' T8 d3 a& q
lock指示该帐户是否被用户锁定。客户不应将资金用于锁定的账户。" u& s2 P& x+ t6 W+ H# G/ a( q1 A
key是NEP-2格式的帐户的私钥。该字段可以是null(仅用于监视地址或非标准地址)。
0 S2 F. C! N5 `& w$ Wcontract是描述合同细节的合约对象。这个字段可以是null(仅供观看地址)。3 r! q; l6 g, G2 ^& w4 I
extra是由客户的实现者定义的用于存储额外数据的对象。这个字段可以null。
1 q% l0 z" D9 u" o  z$ N" m2 c合约
! R0 T  P( ^+ X9 \, |( I合约对象具有以下结构:
! ], j& [- h3 N' Z8 @9 q) p+ O{0 B; P9 M+ U( H9 A: p' T
  "script": "21036dc4bf8f0405dcf5d12a38487b359cb4bd693357a387d74fc438ffc7757948b0ac",$ @+ N( ]$ L& e* `! M; f
  "parameters": [],
4 ^3 y* B& {# d: E/ q. J$ H( n5 q  "deployed": false
- U+ H4 S$ c! L0 k}. T& K( H+ s0 n, p' _' {. Q
script 是合同的脚本代码。如果合同已经部署到区块链,这个字段可以是null。
+ c: L6 @- c/ C2 ~parameters 是一个Parameter对象的数组,它描述了契约函数中每个参数的细节。有关Parameter对象的更多信息,请参阅NEP-3:NeoContract ABI中的说明。(https://github.com/neo-project/proposals/blob/master/nep-3.mediawiki. O' y# O+ ], F/ g; a
deployed 表示合约是否已经部署到区块链。- N$ l. U$ t% s- r' R% c& z
旧版兼容性
/ I) [: @- ?& m  N4 Q所有旧格式的钱包应该可以很容易地转换成这个新的JSON格式。如果这些钱包文件包含一些额外的数据,它们可以存储在文件中extra。% c# O4 q7 P/ x: f/ T+ {
应用
" i. |: z( |9 ineo-project / neo:https://github.com/neo-project/neo/blob/master/neo/Implementations/Wallets/NEP6/NEP6Wallet.cs
: w" V0 ^8 t+ q$ e# X  ~+ uCityOfZion / neon-js:https://github.com/CityOfZion/neon-js/blob/feature/nep-wallet/src/wallet/Wallet.js
BitMere.com 比特池塘系信息发布平台,比特池塘仅提供信息存储空间服务。
声明:该文观点仅代表作者本人,本文不代表比特池塘立场,且不构成建议,请谨慎对待。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

成为第一个吐槽的人

哈哈笑417 初中生
  • 粉丝

    0

  • 关注

    0

  • 主题

    11