Hi 游客

更多精彩,请登录!

比特池塘 区块链技术 正文

NEP-6钱包标准

哈哈笑417
100 0 0
NEP:NEO Enhancement Proposals,即NEO改进提案,描述了NEO平台的标准,包括核心协议规范,客户端API和合约标准等。最为熟知的是NEP-5代币标准。3 o+ m) ]" @; T7 U: n$ @
目前NEP-6钱包标准已经完成,以下为NEP-6钱包标准的Github文档(https://github.com/neo-project/proposals/blob/master/nep-6.mediawiki
) a3 w  F8 N* v4 L摘要
' x3 d6 k+ q" c- n6 @; yNEP-6描述了一个钱包标准,将支持钱包文件在NEO的各种钱包客户端之间共享。, a& Z  m# W9 D$ P3 W3 X1 I# f
目标" I% a0 t7 X! D' G  ]4 ]
目前,不同的客户端程序会生成不同的钱包文件。他们有不同的文件格式,不同的存储方式,以及不同的加密方式。用户难以在不同的客户端程序之间迁移,因为钱包文件格式不同。尽管可以通过导出私钥来实现移植,但是对于具有多个私钥的钱包而言,这是非常麻烦的。我们需要一个通用的钱包格式,允许用户安全而轻松地迁移到所有平台上,而无需更改钱包文件或导出私钥。0 C7 r# z# H6 K6 ?6 X. f  `
基本原理' G1 ^' m1 }6 s! z
钱包标准应该考虑安全性和跨平台兼容性。为了安全起见,我们要求实现使用NEP-2(https://github.com/neo-project/proposals/blob/master/nep-2.mediawiki)机制来加密或解密私钥。为了达成跨平台要求,我们使用JSON格式来描述钱包文件,以便在每个平台上能够识别钱包文件的内容。
5 H% ^: ~! ]+ r0 ^. g4 }规范& O( h- }4 |: r4 v) |( k
JSON格式的钱包文件由以下内容构成基本结构
& f0 ]+ W$ ?( w( s5 A; n{
; l0 x$ g; D7 o  "name": "MyWallet",: f3 q7 k) X) Z8 |% W2 e3 n
  "version": "1.0"," ~0 a6 k* @$ o9 i1 T; R2 l8 ?  f+ ~
  "scrypt": {},
, L) Q; W8 o$ K( z/ q9 t/ ]  "accounts": [],$ l2 [3 O0 u1 K
  "extra": null" y7 x! h; a  C9 R/ L
}9 h7 L9 a7 v$ R  |
name 是用户对钱包文件所做的标记。
' q( W& j2 L5 G9 Rversion目前已经修复1.0并将用于未来的功能升级。2 N1 Z" f/ S7 E( ^5 S
scrypt 是一个ScryptParameters对象,它描述了用于加密和解密钱包中私钥的SCrypt算法的参数。
- {$ B! A# h* A8 eaccounts 是一个Account对象的数组,用于描述钱包中每个账户的详细信息。
$ [2 {- {$ D; T* t' Z# g' d' [3 sextra 是由客户的实现者定义的用于存储额外数据的对象。这个字段可以null。9 w. s0 B: _4 S6 N) d9 {
ScryptParameters+ d8 ~" t+ x5 v. A
ScryptParameters对象具有以下结构:: S3 t; ~+ Z9 }: p3 \' Y& W* d
{5 {0 b0 m. g9 q& l# y
  “n”:16384,( `1 y! k5 T# h. y$ y3 S6 }
  “r”:8,
) a' r, I- K0 |0 k  g  Y  “p”:8}$ z2 W8 K2 Q9 F  x4 ~
n是定义CPU /内存成本的参数。必须是2 ^ N的值。8 v9 P/ t# H) s; s& i4 n
r 是一个调整参数。# l: ^# g7 q2 {- z
p是一个调整参数(并行参数)。大的p值会增加SCrypt的计算成本,而不会增加内存使用量。; M3 b+ v) J: I  a
账户
3 [1 u" B# X  C账户对象具有以下结构:
: b# ~3 c# W! M! |" q1 L! A2 g" G{
5 E! O, f$ m, V6 g! ?  “address”:“AQLASLtT6pWbThcSCYU1biVqhMnzhTgLFq”,
* b9 s! }$ B6 Z  “label”:“MyAddress”,( E- b3 s0 T& Z
  “isDefault”:true,
' q" ~' n( w# y: G  “lock”:false,* h( O8 u5 ?9 Q  r
  “key”:“6PYWB8m1bCnu5bQkRUKAwbZp2BHNvQ3BQRLbpLdTuizpyLkQPSZbtZfoxx”,
3 ~) A- q% c1 R8 y7 K1 P  “contract”:{},
4 N, U1 N& r- A( S1 j0 q/ E  “extra”:null}
, ]. @' `8 k7 h3 o4 e! Gaddress 是帐户的base58编码地址。( L4 e( H/ x6 ~2 }2 T
label 是用户对帐户所做的标签。& Y9 s- a" U% F* M" U! ?* u
isDefault 指示该帐户是否是默认的更改帐户。
# T9 ]/ z9 @! h6 i; X5 Dlock指示该帐户是否被用户锁定。客户不应将资金用于锁定的账户。
9 z4 H" W" n4 d. i& ?7 X- ykey是NEP-2格式的帐户的私钥。该字段可以是null(仅用于监视地址或非标准地址)。
( z. k' O1 ^6 b, v, x2 v. Fcontract是描述合同细节的合约对象。这个字段可以是null(仅供观看地址)。( A- C) O, G- }6 g, }1 Q% p# Q3 V5 P
extra是由客户的实现者定义的用于存储额外数据的对象。这个字段可以null。
$ b3 a# A2 I0 x0 I* O) n! m! J5 F合约
7 c2 q" e- v' K( |8 k  z# I) }' R合约对象具有以下结构:* D: V8 r: C" |/ N# e! A% H
{
0 w/ m* w3 a/ s  "script": "21036dc4bf8f0405dcf5d12a38487b359cb4bd693357a387d74fc438ffc7757948b0ac",
  L1 ]$ ^# Q7 h$ }% i2 E$ ~& M& H# P  "parameters": [],* K; X: s2 o1 s# r$ W, [( \5 Q
  "deployed": false/ Q! f% K8 X' k$ I
}. w, y! u& l& `' m' O+ c* z
script 是合同的脚本代码。如果合同已经部署到区块链,这个字段可以是null。
9 g1 f) ]' o8 v  p2 ^parameters 是一个Parameter对象的数组,它描述了契约函数中每个参数的细节。有关Parameter对象的更多信息,请参阅NEP-3:NeoContract ABI中的说明。(https://github.com/neo-project/proposals/blob/master/nep-3.mediawiki- R' `3 b7 h0 T
deployed 表示合约是否已经部署到区块链。
% t$ H( ~& `) l. c, s旧版兼容性
7 Q) p. n4 s: k( Q$ A0 t  ~所有旧格式的钱包应该可以很容易地转换成这个新的JSON格式。如果这些钱包文件包含一些额外的数据,它们可以存储在文件中extra。
, J. ?0 ^  `/ T& R; n' A5 M8 ?应用. Z. I/ K' ~* w9 U& z
neo-project / neo:https://github.com/neo-project/neo/blob/master/neo/Implementations/Wallets/NEP6/NEP6Wallet.cs1 Y3 `% W; W+ g4 @+ y
CityOfZion / neon-js:https://github.com/CityOfZion/neon-js/blob/feature/nep-wallet/src/wallet/Wallet.js
BitMere.com 比特池塘系信息发布平台,比特池塘仅提供信息存储空间服务。
声明:该文观点仅代表作者本人,本文不代表比特池塘立场,且不构成建议,请谨慎对待。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

成为第一个吐槽的人

哈哈笑417 初中生
  • 粉丝

    0

  • 关注

    0

  • 主题

    11