Hi 游客

更多精彩,请登录!

比特池塘 区块链技术 正文

NEP-6钱包标准

哈哈笑417
191 0 0
NEP:NEO Enhancement Proposals,即NEO改进提案,描述了NEO平台的标准,包括核心协议规范,客户端API和合约标准等。最为熟知的是NEP-5代币标准。
9 i9 w% w9 A2 h" A/ |目前NEP-6钱包标准已经完成,以下为NEP-6钱包标准的Github文档(https://github.com/neo-project/proposals/blob/master/nep-6.mediawiki
, Z) H# n6 E7 O7 f( {! i摘要9 a- a- S$ i( |
NEP-6描述了一个钱包标准,将支持钱包文件在NEO的各种钱包客户端之间共享。
3 K3 J6 ]3 B8 r8 s6 C% v7 a3 t目标% v8 y+ G( o  c, r! V
目前,不同的客户端程序会生成不同的钱包文件。他们有不同的文件格式,不同的存储方式,以及不同的加密方式。用户难以在不同的客户端程序之间迁移,因为钱包文件格式不同。尽管可以通过导出私钥来实现移植,但是对于具有多个私钥的钱包而言,这是非常麻烦的。我们需要一个通用的钱包格式,允许用户安全而轻松地迁移到所有平台上,而无需更改钱包文件或导出私钥。- [2 c# p9 U) ^( V, s! S! I
基本原理# a$ Z- K& R3 `* F9 m
钱包标准应该考虑安全性和跨平台兼容性。为了安全起见,我们要求实现使用NEP-2(https://github.com/neo-project/proposals/blob/master/nep-2.mediawiki)机制来加密或解密私钥。为了达成跨平台要求,我们使用JSON格式来描述钱包文件,以便在每个平台上能够识别钱包文件的内容。
- Z( F7 y& M* S6 ^! I" e! x规范* r2 r; w8 Z/ \5 b$ u7 B  q
JSON格式的钱包文件由以下内容构成基本结构( ~+ g, U" M0 D  L# E6 v
{$ i. m& ]+ ~: X2 G5 J) b" f
  "name": "MyWallet",0 T% v* h0 ~' ?
  "version": "1.0",0 H. D. t' {2 z3 P$ m6 u' f3 p- A
  "scrypt": {},0 f" R% x2 P' g3 ~
  "accounts": [],) S$ i- C) ?7 I+ H* l
  "extra": null$ g0 h9 C" h2 z
}
. T. V$ {. X) X5 D3 l: V* Qname 是用户对钱包文件所做的标记。3 l/ l% }4 S8 D
version目前已经修复1.0并将用于未来的功能升级。8 e' L) z  e/ _9 O& k
scrypt 是一个ScryptParameters对象,它描述了用于加密和解密钱包中私钥的SCrypt算法的参数。0 f& l* h* ]  a& I
accounts 是一个Account对象的数组,用于描述钱包中每个账户的详细信息。3 j" T$ P* U+ r- _5 e& S) v% H& h7 Y% L6 b
extra 是由客户的实现者定义的用于存储额外数据的对象。这个字段可以null。7 @" \7 d: _$ Z, f" ]/ V, F# i, v6 I
ScryptParameters- }/ ~( w( z! [  [' K  Y! E* p
ScryptParameters对象具有以下结构:
& g7 r% p  u4 s+ h9 u{2 W& l8 r/ B9 V' ~7 E0 e
  “n”:16384,
1 g" H9 A% Z. g7 Y3 W* m% K; G: j' K  “r”:8,
& @1 V8 K. A- F1 i" S  “p”:8}
9 }9 m2 D# u* r# X) m& s6 u% {: E" qn是定义CPU /内存成本的参数。必须是2 ^ N的值。# E' t( i$ o$ B9 [. g. k1 V) R' L
r 是一个调整参数。
& J2 P! [6 t* f- G3 q* ?p是一个调整参数(并行参数)。大的p值会增加SCrypt的计算成本,而不会增加内存使用量。
! _& }3 Y& ]( K& C, @' Z+ F( H+ t账户7 g9 U& T/ q  Q8 C6 V) S
账户对象具有以下结构:2 U8 A$ ^& V! y
{
- O- P$ r) ~( Z  “address”:“AQLASLtT6pWbThcSCYU1biVqhMnzhTgLFq”,/ {# _: K3 ]; |8 S9 r, N- G
  “label”:“MyAddress”,
- g- O6 H' v. L  “isDefault”:true,' t7 _; ?/ K8 g" ~
  “lock”:false,, I/ H+ U3 h* z% ~; X9 e( ]! Q  w, M
  “key”:“6PYWB8m1bCnu5bQkRUKAwbZp2BHNvQ3BQRLbpLdTuizpyLkQPSZbtZfoxx”,3 i! ~2 W0 V6 d6 R1 i3 H* B
  “contract”:{},( y+ z0 D# O" H% ~3 J& m
  “extra”:null}
( d2 v" c% [( r9 Baddress 是帐户的base58编码地址。
$ \- N; J0 W5 olabel 是用户对帐户所做的标签。
7 s8 D# U0 _0 G" E7 }isDefault 指示该帐户是否是默认的更改帐户。5 |. u* N; ~1 ^7 f
lock指示该帐户是否被用户锁定。客户不应将资金用于锁定的账户。# ^0 g8 \6 P, r; |
key是NEP-2格式的帐户的私钥。该字段可以是null(仅用于监视地址或非标准地址)。! k6 A" d1 ?7 K- I% c
contract是描述合同细节的合约对象。这个字段可以是null(仅供观看地址)。
/ V/ n. j/ k/ |5 t  x' n7 Fextra是由客户的实现者定义的用于存储额外数据的对象。这个字段可以null。
) D7 q. Q) g# {# M5 w7 F  T合约
$ x0 Z, [* K8 S. F6 l! a) b' u合约对象具有以下结构:
" \* ?) w  t7 B% f" r# b{
4 @  c% U& M+ K+ V% d$ @  v  "script": "21036dc4bf8f0405dcf5d12a38487b359cb4bd693357a387d74fc438ffc7757948b0ac",, X7 o& g+ x& t2 ^
  "parameters": [],
$ r* P3 R/ d" c5 O4 P  "deployed": false! S* I6 X1 R6 Q" k" {; y/ _
}
1 [9 z. ?; r2 V3 b# oscript 是合同的脚本代码。如果合同已经部署到区块链,这个字段可以是null。
; ^' J' y8 w  m2 y: C/ Y, {4 w' Zparameters 是一个Parameter对象的数组,它描述了契约函数中每个参数的细节。有关Parameter对象的更多信息,请参阅NEP-3:NeoContract ABI中的说明。(https://github.com/neo-project/proposals/blob/master/nep-3.mediawiki6 ~: G6 P" N8 O: q! ?
deployed 表示合约是否已经部署到区块链。
' q$ S( a+ k# W; M7 F/ s4 L0 I旧版兼容性
/ K. @1 n  H2 G1 ~所有旧格式的钱包应该可以很容易地转换成这个新的JSON格式。如果这些钱包文件包含一些额外的数据,它们可以存储在文件中extra。1 S4 ?* @3 f9 q
应用' _: ^) ^) _3 I; ~
neo-project / neo:https://github.com/neo-project/neo/blob/master/neo/Implementations/Wallets/NEP6/NEP6Wallet.cs
8 a7 V! r" b: z- dCityOfZion / neon-js:https://github.com/CityOfZion/neon-js/blob/feature/nep-wallet/src/wallet/Wallet.js
BitMere.com 比特池塘系信息发布平台,比特池塘仅提供信息存储空间服务。
声明:该文观点仅代表作者本人,本文不代表比特池塘立场,且不构成建议,请谨慎对待。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

成为第一个吐槽的人

哈哈笑417 初中生
  • 粉丝

    0

  • 关注

    0

  • 主题

    11