Hi 游客

更多精彩,请登录!

比特池塘 区块链技术 正文

NEP-6钱包标准

哈哈笑417
97 0 0
NEP:NEO Enhancement Proposals,即NEO改进提案,描述了NEO平台的标准,包括核心协议规范,客户端API和合约标准等。最为熟知的是NEP-5代币标准。: R( l& Y5 R" |- @  b
目前NEP-6钱包标准已经完成,以下为NEP-6钱包标准的Github文档(https://github.com/neo-project/proposals/blob/master/nep-6.mediawiki& \$ Y8 P- j; |+ C
摘要
% G* v5 s) h: M. U5 T7 `# {NEP-6描述了一个钱包标准,将支持钱包文件在NEO的各种钱包客户端之间共享。' R4 y1 O/ l* Q6 w  a+ \
目标
+ l: K$ U' F# j" w4 D7 k' j目前,不同的客户端程序会生成不同的钱包文件。他们有不同的文件格式,不同的存储方式,以及不同的加密方式。用户难以在不同的客户端程序之间迁移,因为钱包文件格式不同。尽管可以通过导出私钥来实现移植,但是对于具有多个私钥的钱包而言,这是非常麻烦的。我们需要一个通用的钱包格式,允许用户安全而轻松地迁移到所有平台上,而无需更改钱包文件或导出私钥。  ?3 p* x/ e  c/ r
基本原理
$ C# f' ^. G% A; Z- }* l钱包标准应该考虑安全性和跨平台兼容性。为了安全起见,我们要求实现使用NEP-2(https://github.com/neo-project/proposals/blob/master/nep-2.mediawiki)机制来加密或解密私钥。为了达成跨平台要求,我们使用JSON格式来描述钱包文件,以便在每个平台上能够识别钱包文件的内容。- t# h; H4 E0 ?: x
规范% {) p9 ?( S1 `& x! O
JSON格式的钱包文件由以下内容构成基本结构6 q; F% j" c9 _4 v' z" J: S( D0 O
{- m, y7 ~) `6 i+ A9 f
  "name": "MyWallet",
  |2 V7 y, X* {; h' y% a4 o  "version": "1.0",% n. @0 q1 B* |4 o1 A
  "scrypt": {},) S: ^; u/ z5 O- p0 D4 n+ L. ?5 J
  "accounts": [],
' z! W8 ]1 {: J  "extra": null7 |: B. F5 W/ m
}% L2 m  _; F  O' X$ A& ~" r. j4 i( I
name 是用户对钱包文件所做的标记。
( {2 ], {% u; D& ?+ Q: J' T2 ^6 Zversion目前已经修复1.0并将用于未来的功能升级。
! j9 U% v* w! ]1 F2 |8 u: ?. Rscrypt 是一个ScryptParameters对象,它描述了用于加密和解密钱包中私钥的SCrypt算法的参数。
- D/ s: J5 R' Z! w- q8 gaccounts 是一个Account对象的数组,用于描述钱包中每个账户的详细信息。: Q7 N8 Q  x' e3 q5 X
extra 是由客户的实现者定义的用于存储额外数据的对象。这个字段可以null。4 r! o9 ?' m% C( o+ @/ M, p' p
ScryptParameters  F- C, ?3 }5 }/ ~8 \
ScryptParameters对象具有以下结构:
" v( e3 ?9 D" N, {& y8 a9 E+ h{
% T  K4 G+ _+ K) B* `0 X  “n”:16384,
4 U3 Z. C2 i! [' |: _/ u  “r”:8,
) T4 u. F' l+ y  “p”:8}
. J1 z9 G! |1 q/ `' A' Yn是定义CPU /内存成本的参数。必须是2 ^ N的值。
) O& O0 Y) }( k' F0 g3 b+ ~r 是一个调整参数。1 g& X) c9 C4 B$ G8 b* W
p是一个调整参数(并行参数)。大的p值会增加SCrypt的计算成本,而不会增加内存使用量。
& e, p/ L2 \1 C: u, g账户+ a0 n8 h2 Y$ T8 T, q! m. k0 h
账户对象具有以下结构:4 M, V! P0 S, n! V& u) t
{
# O8 g' ?) e* d5 j  “address”:“AQLASLtT6pWbThcSCYU1biVqhMnzhTgLFq”,
3 F6 i8 t# q  F( f  “label”:“MyAddress”,9 P: ?6 T# Y6 w: h+ V
  “isDefault”:true,
4 X! N# ~9 I! T8 O; T  “lock”:false,
1 I6 n* I7 C: Z8 A/ s2 t  “key”:“6PYWB8m1bCnu5bQkRUKAwbZp2BHNvQ3BQRLbpLdTuizpyLkQPSZbtZfoxx”,
  [2 H4 I3 n$ V5 c  “contract”:{},8 H2 Y3 @, ~% f: f; X
  “extra”:null}, ?/ @. Y" ]) n. W; I" ~  f
address 是帐户的base58编码地址。/ c* T( h6 S% s# H3 y: b
label 是用户对帐户所做的标签。) f; V. U/ @1 M
isDefault 指示该帐户是否是默认的更改帐户。
+ P9 @# U/ _+ m% v( N+ Alock指示该帐户是否被用户锁定。客户不应将资金用于锁定的账户。
. V1 H- K! L4 D$ ?/ g1 ^key是NEP-2格式的帐户的私钥。该字段可以是null(仅用于监视地址或非标准地址)。
1 O) b8 I) O6 O4 q% Kcontract是描述合同细节的合约对象。这个字段可以是null(仅供观看地址)。. {5 F4 f+ `! j: a0 v) ?: }+ f
extra是由客户的实现者定义的用于存储额外数据的对象。这个字段可以null。
% p* Z. P, ]4 N( W( H8 ]+ ~. U合约
' @& E& z! X. U合约对象具有以下结构:- [$ H' P! q, I2 @' Y
{7 Z2 b$ V: T% s4 Q
  "script": "21036dc4bf8f0405dcf5d12a38487b359cb4bd693357a387d74fc438ffc7757948b0ac",& q) x- K; l4 C/ q& |7 y' h
  "parameters": [],
( M0 ]1 z  y! W/ \  "deployed": false
4 q2 p! l; \& Y& C: k}4 k/ X) l5 J1 R) |+ z! N- J
script 是合同的脚本代码。如果合同已经部署到区块链,这个字段可以是null。
: N2 |6 p7 v  E" U# C0 `) R$ d. eparameters 是一个Parameter对象的数组,它描述了契约函数中每个参数的细节。有关Parameter对象的更多信息,请参阅NEP-3:NeoContract ABI中的说明。(https://github.com/neo-project/proposals/blob/master/nep-3.mediawiki. ?$ O* e3 C% b; U: g
deployed 表示合约是否已经部署到区块链。
$ ~) |* H7 a! o( P8 T  K: d旧版兼容性
% Q" S8 W- B! k/ _3 T5 X0 ?) _所有旧格式的钱包应该可以很容易地转换成这个新的JSON格式。如果这些钱包文件包含一些额外的数据,它们可以存储在文件中extra。; V; P7 y/ ~+ ^- F+ x7 k
应用( u& W' ?5 K0 r$ M* w
neo-project / neo:https://github.com/neo-project/neo/blob/master/neo/Implementations/Wallets/NEP6/NEP6Wallet.cs) l$ V  Z9 T. ~
CityOfZion / neon-js:https://github.com/CityOfZion/neon-js/blob/feature/nep-wallet/src/wallet/Wallet.js
BitMere.com 比特池塘系信息发布平台,比特池塘仅提供信息存储空间服务。
声明:该文观点仅代表作者本人,本文不代表比特池塘立场,且不构成建议,请谨慎对待。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

成为第一个吐槽的人

哈哈笑417 初中生
  • 粉丝

    0

  • 关注

    0

  • 主题

    11