Hi 游客

更多精彩,请登录!

比特池塘 区块链技术 正文

NEP-6钱包标准

哈哈笑417
188 0 0
NEP:NEO Enhancement Proposals,即NEO改进提案,描述了NEO平台的标准,包括核心协议规范,客户端API和合约标准等。最为熟知的是NEP-5代币标准。
4 q& b& c+ }* R2 z/ J目前NEP-6钱包标准已经完成,以下为NEP-6钱包标准的Github文档(https://github.com/neo-project/proposals/blob/master/nep-6.mediawiki% F; ^% H" ~2 d* [
摘要' t0 k4 j, @/ Z/ Q
NEP-6描述了一个钱包标准,将支持钱包文件在NEO的各种钱包客户端之间共享。
* R0 |3 _1 Y, b! V目标* A. V) g9 c! }
目前,不同的客户端程序会生成不同的钱包文件。他们有不同的文件格式,不同的存储方式,以及不同的加密方式。用户难以在不同的客户端程序之间迁移,因为钱包文件格式不同。尽管可以通过导出私钥来实现移植,但是对于具有多个私钥的钱包而言,这是非常麻烦的。我们需要一个通用的钱包格式,允许用户安全而轻松地迁移到所有平台上,而无需更改钱包文件或导出私钥。
' b8 H: t! H8 s! }, U基本原理
( t1 H9 y4 k! h( h6 ~+ @3 k钱包标准应该考虑安全性和跨平台兼容性。为了安全起见,我们要求实现使用NEP-2(https://github.com/neo-project/proposals/blob/master/nep-2.mediawiki)机制来加密或解密私钥。为了达成跨平台要求,我们使用JSON格式来描述钱包文件,以便在每个平台上能够识别钱包文件的内容。
4 j/ ?/ N; I, G3 d8 G  X5 b规范
2 o2 t. M9 a: h& V# R/ C# lJSON格式的钱包文件由以下内容构成基本结构4 z2 t2 r0 ?9 \" q* `
{
1 J  R  z* |/ R4 _6 ~  "name": "MyWallet",
# K- g+ P% m' c3 T8 |  "version": "1.0",
, F# V7 l+ T2 ]  v  d  "scrypt": {},
4 l; X7 @5 p+ D$ i$ G  X  "accounts": [],
: f  I+ a% t  f( r9 ^  "extra": null0 I/ V8 F; n; l6 E7 x0 R$ H
}
  i4 |3 i- X; ~name 是用户对钱包文件所做的标记。( A. s# p# h$ z3 b
version目前已经修复1.0并将用于未来的功能升级。3 b2 Q0 N) ?4 f* V. _" c  s' g1 y1 e
scrypt 是一个ScryptParameters对象,它描述了用于加密和解密钱包中私钥的SCrypt算法的参数。
4 X" W; n! T% q& r, Zaccounts 是一个Account对象的数组,用于描述钱包中每个账户的详细信息。
3 R/ }* g( l. |extra 是由客户的实现者定义的用于存储额外数据的对象。这个字段可以null。
) H4 f0 a2 P4 JScryptParameters
& [. s) E& I) q2 ~ScryptParameters对象具有以下结构:
) T0 _+ B' Y* h) s* D{  t5 F$ B; Q/ U
  “n”:16384,
6 H- n4 }" u9 W# {  “r”:8,' A% {5 `* b1 a
  “p”:8}- c, I2 G& k" X# a# b, E6 W$ C+ E
n是定义CPU /内存成本的参数。必须是2 ^ N的值。
% k2 C  P1 Z7 ^+ sr 是一个调整参数。
6 c+ E. B, _" P  jp是一个调整参数(并行参数)。大的p值会增加SCrypt的计算成本,而不会增加内存使用量。/ h3 f/ P2 o5 V  C! n- \( d/ Q8 C
账户0 B8 a- A. X3 d# i0 S
账户对象具有以下结构:
' z7 M9 r. Z# R2 S{( n/ d* Q/ H) I) y
  “address”:“AQLASLtT6pWbThcSCYU1biVqhMnzhTgLFq”,7 z9 Q( O: Q+ R/ w* v
  “label”:“MyAddress”,& S- [, r' u- {8 T1 A; l' S
  “isDefault”:true,) Y, f- o2 Q& x
  “lock”:false,
1 @' A2 @8 V0 Y1 @1 S. }, M  “key”:“6PYWB8m1bCnu5bQkRUKAwbZp2BHNvQ3BQRLbpLdTuizpyLkQPSZbtZfoxx”,% {2 ?2 ^$ V: P
  “contract”:{},
6 W+ ^- q- Q1 f( q5 `  “extra”:null}
: O5 U; Z0 P3 m9 `address 是帐户的base58编码地址。0 T+ O) O) F' o3 K+ F% Q$ r
label 是用户对帐户所做的标签。; A) a+ N0 s3 V
isDefault 指示该帐户是否是默认的更改帐户。
3 w! {  @) r8 l  B6 Block指示该帐户是否被用户锁定。客户不应将资金用于锁定的账户。6 o8 m1 e5 H8 y, s1 H
key是NEP-2格式的帐户的私钥。该字段可以是null(仅用于监视地址或非标准地址)。2 L$ G5 @2 F1 y2 \# ^( y' x
contract是描述合同细节的合约对象。这个字段可以是null(仅供观看地址)。
1 n# R& F$ N/ |' L, C$ s0 mextra是由客户的实现者定义的用于存储额外数据的对象。这个字段可以null。1 S* m% `1 Y& G: ~, [4 k; C; Q9 S
合约
8 K% s$ i/ [+ D( B+ ^合约对象具有以下结构:
. Y! ?4 S1 K' r{
% ]! g/ n* T5 s5 Q4 ]5 d7 ]) i; e/ y  "script": "21036dc4bf8f0405dcf5d12a38487b359cb4bd693357a387d74fc438ffc7757948b0ac",1 P. _! }0 H/ x' \$ P0 |
  "parameters": [],* c' I; u8 T2 s" c$ W. F; d  @1 H+ Z: l
  "deployed": false
( u' J" _; f1 r) c2 x+ `}
# r" O  ]+ M- ?/ r1 K* qscript 是合同的脚本代码。如果合同已经部署到区块链,这个字段可以是null。9 q3 U- T& ~! [- W9 l
parameters 是一个Parameter对象的数组,它描述了契约函数中每个参数的细节。有关Parameter对象的更多信息,请参阅NEP-3:NeoContract ABI中的说明。(https://github.com/neo-project/proposals/blob/master/nep-3.mediawiki' Y0 I2 |7 P; y+ h+ a  f  f
deployed 表示合约是否已经部署到区块链。
  ^) [3 ^# i1 b6 s* O8 @; R' v旧版兼容性8 `9 I: I: I0 e( f" e  M
所有旧格式的钱包应该可以很容易地转换成这个新的JSON格式。如果这些钱包文件包含一些额外的数据,它们可以存储在文件中extra。0 l8 k0 F8 _# S) d6 ]5 `
应用- v5 b9 U; s. v# Z1 [; I0 I
neo-project / neo:https://github.com/neo-project/neo/blob/master/neo/Implementations/Wallets/NEP6/NEP6Wallet.cs: @) K- \$ t* e1 ?/ s  _( J
CityOfZion / neon-js:https://github.com/CityOfZion/neon-js/blob/feature/nep-wallet/src/wallet/Wallet.js
BitMere.com 比特池塘系信息发布平台,比特池塘仅提供信息存储空间服务。
声明:该文观点仅代表作者本人,本文不代表比特池塘立场,且不构成建议,请谨慎对待。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

成为第一个吐槽的人

哈哈笑417 初中生
  • 粉丝

    0

  • 关注

    0

  • 主题

    11