Hi 游客

更多精彩,请登录!

比特池塘 区块链技术 正文

NEP-6钱包标准

哈哈笑417
104 0 0
NEP:NEO Enhancement Proposals,即NEO改进提案,描述了NEO平台的标准,包括核心协议规范,客户端API和合约标准等。最为熟知的是NEP-5代币标准。
4 X$ R2 P6 u0 x2 b/ d6 ]: \& E7 h目前NEP-6钱包标准已经完成,以下为NEP-6钱包标准的Github文档(https://github.com/neo-project/proposals/blob/master/nep-6.mediawiki& Q8 i/ J3 K4 a# u% k- N8 j; p
摘要4 B% V( X6 W% j9 I
NEP-6描述了一个钱包标准,将支持钱包文件在NEO的各种钱包客户端之间共享。* Y* R1 P* M% x; r4 G8 {: j! W
目标
2 F. s8 P6 G( P' `7 \( E- m; Z目前,不同的客户端程序会生成不同的钱包文件。他们有不同的文件格式,不同的存储方式,以及不同的加密方式。用户难以在不同的客户端程序之间迁移,因为钱包文件格式不同。尽管可以通过导出私钥来实现移植,但是对于具有多个私钥的钱包而言,这是非常麻烦的。我们需要一个通用的钱包格式,允许用户安全而轻松地迁移到所有平台上,而无需更改钱包文件或导出私钥。
% o3 K; @! ^  H3 {基本原理7 s% S# a, y4 H; K
钱包标准应该考虑安全性和跨平台兼容性。为了安全起见,我们要求实现使用NEP-2(https://github.com/neo-project/proposals/blob/master/nep-2.mediawiki)机制来加密或解密私钥。为了达成跨平台要求,我们使用JSON格式来描述钱包文件,以便在每个平台上能够识别钱包文件的内容。
* ]9 [0 ?5 o2 b1 b规范
4 \9 m& Y0 h% W% D, Z2 \$ F8 p) \JSON格式的钱包文件由以下内容构成基本结构
7 i, w2 _+ r/ L{- `% Y) ~! D, N! D
  "name": "MyWallet",
& {8 L* \4 N0 N. d/ V" U  A; q% Z  "version": "1.0",
2 y( M. K, G' S$ |$ N  "scrypt": {},6 J9 Z- T1 {& @8 s1 F. @6 q
  "accounts": [],
- t+ n$ W. D& w" I& m# j7 e  "extra": null
" [* I! u2 I4 C( u' V- }$ K}
6 |3 T9 o7 h# T% w8 zname 是用户对钱包文件所做的标记。
8 N- `+ t( h4 e, Nversion目前已经修复1.0并将用于未来的功能升级。
+ P* }" X0 @) |3 ]1 T: Z4 I" \scrypt 是一个ScryptParameters对象,它描述了用于加密和解密钱包中私钥的SCrypt算法的参数。
4 I  e# @/ c# C/ y) `accounts 是一个Account对象的数组,用于描述钱包中每个账户的详细信息。) z# [( G# \2 x5 P) V. q3 d
extra 是由客户的实现者定义的用于存储额外数据的对象。这个字段可以null。
: w$ g4 z# i+ N$ mScryptParameters/ X6 o( r' y& x$ ~/ }- O, @* p
ScryptParameters对象具有以下结构:
2 B* l# a9 C, u% A) X( i, i{0 e6 Z  n$ B9 f  D& v& ~. B7 K
  “n”:16384,( t) |4 _3 q, ?5 k
  “r”:8,5 U/ P6 k& {/ e8 H, p0 u; b
  “p”:8}" W- H; c( @" f1 q' I; J6 I! s3 }
n是定义CPU /内存成本的参数。必须是2 ^ N的值。) [4 H6 R9 t1 s
r 是一个调整参数。
3 N3 G# F2 N1 q! Y% N+ ]. }p是一个调整参数(并行参数)。大的p值会增加SCrypt的计算成本,而不会增加内存使用量。7 ]5 j- G( p* L& A8 k: r+ _
账户+ Z% u1 u# q+ \  h& r. K
账户对象具有以下结构:4 @! r8 N  v/ b- w0 u- @
{8 s9 S9 @- R8 x2 U% M
  “address”:“AQLASLtT6pWbThcSCYU1biVqhMnzhTgLFq”,! c# B* ?- X6 Z- }5 F2 B/ [
  “label”:“MyAddress”,
1 L* M1 l9 `/ z+ J  “isDefault”:true,5 C# @6 _+ B2 \* l
  “lock”:false,
1 b  \2 W3 V$ H$ f" ~% ?% Z; n  “key”:“6PYWB8m1bCnu5bQkRUKAwbZp2BHNvQ3BQRLbpLdTuizpyLkQPSZbtZfoxx”,/ r4 d- l& W, D* n; E. M+ p
  “contract”:{},
  p9 |+ Y+ ^$ k8 \: t, P: n  “extra”:null}7 i+ r$ L% x8 H. Z
address 是帐户的base58编码地址。
: h$ f- w5 O* s( u! tlabel 是用户对帐户所做的标签。
2 m2 [/ q: X9 N, wisDefault 指示该帐户是否是默认的更改帐户。7 @8 x+ X& X( C& n$ F! D" U
lock指示该帐户是否被用户锁定。客户不应将资金用于锁定的账户。5 z; t: w% A, r! x1 \; n, U
key是NEP-2格式的帐户的私钥。该字段可以是null(仅用于监视地址或非标准地址)。
7 W% W$ R/ k7 g) g4 S! [contract是描述合同细节的合约对象。这个字段可以是null(仅供观看地址)。
2 b& S+ c/ Q- {, gextra是由客户的实现者定义的用于存储额外数据的对象。这个字段可以null。# k6 I7 p; M1 H+ k" p0 ]( T( @0 f( C/ U
合约7 z3 L1 ~8 m7 h4 W" i1 I' b3 `& p
合约对象具有以下结构:2 @) A+ N  o) s6 ]- f
{) @6 p2 L8 d8 |$ o
  "script": "21036dc4bf8f0405dcf5d12a38487b359cb4bd693357a387d74fc438ffc7757948b0ac",
- R% g7 y7 D7 V% Y% g  "parameters": [],
3 H) e2 P: P/ V! C# u+ o$ ]  "deployed": false
1 u0 x  c+ H: a; P% K  K0 K% ]}3 n6 P& \5 M  V  R3 A- C
script 是合同的脚本代码。如果合同已经部署到区块链,这个字段可以是null。: D0 W, h5 Q$ U+ n/ C+ f' V
parameters 是一个Parameter对象的数组,它描述了契约函数中每个参数的细节。有关Parameter对象的更多信息,请参阅NEP-3:NeoContract ABI中的说明。(https://github.com/neo-project/proposals/blob/master/nep-3.mediawiki: E! ^& z7 b" K) p6 E9 g$ B
deployed 表示合约是否已经部署到区块链。8 f. @. H6 s( }& d
旧版兼容性
- {+ H4 d* N8 @! U; q" v* G所有旧格式的钱包应该可以很容易地转换成这个新的JSON格式。如果这些钱包文件包含一些额外的数据,它们可以存储在文件中extra。
, j: z1 y; A/ C4 P& o应用
7 G$ n( O2 L* y4 f" K0 X& Yneo-project / neo:https://github.com/neo-project/neo/blob/master/neo/Implementations/Wallets/NEP6/NEP6Wallet.cs
3 J( t* v, n( ]) nCityOfZion / neon-js:https://github.com/CityOfZion/neon-js/blob/feature/nep-wallet/src/wallet/Wallet.js
BitMere.com 比特池塘系信息发布平台,比特池塘仅提供信息存储空间服务。
声明:该文观点仅代表作者本人,本文不代表比特池塘立场,且不构成建议,请谨慎对待。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

成为第一个吐槽的人

哈哈笑417 初中生
  • 粉丝

    0

  • 关注

    0

  • 主题

    11