Hi 游客

更多精彩,请登录!

比特池塘 区块链技术 正文

NEP-6钱包标准

哈哈笑417
197 0 0
NEP:NEO Enhancement Proposals,即NEO改进提案,描述了NEO平台的标准,包括核心协议规范,客户端API和合约标准等。最为熟知的是NEP-5代币标准。
( S. l$ b. F$ _目前NEP-6钱包标准已经完成,以下为NEP-6钱包标准的Github文档(https://github.com/neo-project/proposals/blob/master/nep-6.mediawiki; b5 H+ V9 N3 O; H) D% F( b0 [
摘要, U: |6 A/ ~2 N( \% D! I
NEP-6描述了一个钱包标准,将支持钱包文件在NEO的各种钱包客户端之间共享。# x" F8 y+ _' f  |% c
目标) d2 _0 C" G, U1 w5 _$ q8 b
目前,不同的客户端程序会生成不同的钱包文件。他们有不同的文件格式,不同的存储方式,以及不同的加密方式。用户难以在不同的客户端程序之间迁移,因为钱包文件格式不同。尽管可以通过导出私钥来实现移植,但是对于具有多个私钥的钱包而言,这是非常麻烦的。我们需要一个通用的钱包格式,允许用户安全而轻松地迁移到所有平台上,而无需更改钱包文件或导出私钥。; K9 g0 W& [. f5 Z0 s7 _
基本原理
( V7 @' V6 z4 m钱包标准应该考虑安全性和跨平台兼容性。为了安全起见,我们要求实现使用NEP-2(https://github.com/neo-project/proposals/blob/master/nep-2.mediawiki)机制来加密或解密私钥。为了达成跨平台要求,我们使用JSON格式来描述钱包文件,以便在每个平台上能够识别钱包文件的内容。! v# f! G1 |3 o
规范
& b0 c) v$ p8 u. qJSON格式的钱包文件由以下内容构成基本结构3 i3 T6 x3 L; L+ _4 v# ~
{
: B* G& k$ B: v9 S, s  "name": "MyWallet",, `+ f# U' B% @1 I  M) w6 U: L
  "version": "1.0",. n  T# R% P  K8 H. h7 f
  "scrypt": {},
* ?) u6 S5 z2 \$ X7 D2 g. k1 ?" m  "accounts": [],
1 x: I1 W; {4 a( F% O3 Q  "extra": null, }( x/ C+ h% X4 w9 h' f" ]
}
9 ]3 g* d8 _5 J2 M1 O$ Y% @name 是用户对钱包文件所做的标记。, n& J8 ^" l% `( k
version目前已经修复1.0并将用于未来的功能升级。
7 y+ q3 ?, h+ x0 j3 L  ?scrypt 是一个ScryptParameters对象,它描述了用于加密和解密钱包中私钥的SCrypt算法的参数。
& V6 l, r& l# Z' e, Q2 Kaccounts 是一个Account对象的数组,用于描述钱包中每个账户的详细信息。
0 y8 P; G2 Y/ |; c5 \* Uextra 是由客户的实现者定义的用于存储额外数据的对象。这个字段可以null。
. x* e: B* T6 |2 Q, P  ^% g( B- k% ]ScryptParameters" _; W$ q4 [, \! B$ [% h
ScryptParameters对象具有以下结构:, N, ]# H5 b; C0 G' n+ h
{
! i0 X5 f( v2 m4 {+ t1 ~& E  “n”:16384,
! z9 H2 u4 \1 R  “r”:8,9 C# n3 i- M( s+ |7 R9 [
  “p”:8}
$ P3 ^/ A# U6 w# T  ^) T; un是定义CPU /内存成本的参数。必须是2 ^ N的值。" K- |8 y- V9 M/ E/ O
r 是一个调整参数。8 B) Y1 W8 u) z& n9 n; }
p是一个调整参数(并行参数)。大的p值会增加SCrypt的计算成本,而不会增加内存使用量。  r( }1 x8 M; {6 P
账户
* Q8 x7 K- `* h8 X( B. K* z/ S' b; ]! q# `账户对象具有以下结构:
- u2 N( s$ q6 W) a! q, H{
  p4 d  S. C# T8 E/ T  I/ X& l- u  “address”:“AQLASLtT6pWbThcSCYU1biVqhMnzhTgLFq”,
) Z3 [$ D/ o6 w4 P. M% y8 q  “label”:“MyAddress”,  `0 c( F1 K- J. A! C1 s9 x
  “isDefault”:true,0 G+ R' W4 k# [6 c
  “lock”:false,$ l8 g1 m7 [) J# w) i
  “key”:“6PYWB8m1bCnu5bQkRUKAwbZp2BHNvQ3BQRLbpLdTuizpyLkQPSZbtZfoxx”,9 y# T( G/ n. u6 O# ~& o
  “contract”:{},
3 L- |) [" E% _3 C+ I$ |+ ]& _) H( _  _  “extra”:null}
" A, ]9 T( c  ]* Gaddress 是帐户的base58编码地址。5 \$ Q  R$ Q  O5 J0 u8 y7 P1 V
label 是用户对帐户所做的标签。
; I% v, s2 B6 L0 _, Q- qisDefault 指示该帐户是否是默认的更改帐户。  r8 U0 `3 z/ h
lock指示该帐户是否被用户锁定。客户不应将资金用于锁定的账户。% q' l) s! l* C* e6 g' u+ j6 p
key是NEP-2格式的帐户的私钥。该字段可以是null(仅用于监视地址或非标准地址)。
) G' i1 ~2 q( m# x% \: B! u. f+ r1 gcontract是描述合同细节的合约对象。这个字段可以是null(仅供观看地址)。6 i" U8 J$ p2 X
extra是由客户的实现者定义的用于存储额外数据的对象。这个字段可以null。
; U0 g" F# m2 c; t合约
7 B" G; Z: ]; V$ D; p合约对象具有以下结构:8 Q5 l& ?/ t5 S- a* W' |% a  |
{  m; p1 o* }, L+ }
  "script": "21036dc4bf8f0405dcf5d12a38487b359cb4bd693357a387d74fc438ffc7757948b0ac",9 _2 r5 H2 P  C1 D9 r# V3 G6 a
  "parameters": [],
6 }/ A+ D4 b  d' K  "deployed": false, p) I  f8 B7 ^* a6 F
}
$ i) U) T( H: H& x7 Sscript 是合同的脚本代码。如果合同已经部署到区块链,这个字段可以是null。! P) |' ^/ g4 n  _+ r) P7 r
parameters 是一个Parameter对象的数组,它描述了契约函数中每个参数的细节。有关Parameter对象的更多信息,请参阅NEP-3:NeoContract ABI中的说明。(https://github.com/neo-project/proposals/blob/master/nep-3.mediawiki' Q" {/ `/ H( @) V
deployed 表示合约是否已经部署到区块链。
2 V" J( C0 @% ]6 r+ v8 F) _  ]旧版兼容性
3 v* `- y. O  Z- X; k  R所有旧格式的钱包应该可以很容易地转换成这个新的JSON格式。如果这些钱包文件包含一些额外的数据,它们可以存储在文件中extra。9 g6 w6 N1 X& n1 a$ E- T
应用8 d* Y% y  r+ P2 R5 F8 M+ o
neo-project / neo:https://github.com/neo-project/neo/blob/master/neo/Implementations/Wallets/NEP6/NEP6Wallet.cs) z" B7 B* S9 X
CityOfZion / neon-js:https://github.com/CityOfZion/neon-js/blob/feature/nep-wallet/src/wallet/Wallet.js
BitMere.com 比特池塘系信息发布平台,比特池塘仅提供信息存储空间服务。
声明:该文观点仅代表作者本人,本文不代表比特池塘立场,且不构成建议,请谨慎对待。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

成为第一个吐槽的人

哈哈笑417 初中生
  • 粉丝

    0

  • 关注

    0

  • 主题

    11