Hi 游客

更多精彩,请登录!

比特池塘 区块链技术 正文

NEP-6钱包标准

哈哈笑417
101 0 0
NEP:NEO Enhancement Proposals,即NEO改进提案,描述了NEO平台的标准,包括核心协议规范,客户端API和合约标准等。最为熟知的是NEP-5代币标准。
2 O% v+ s, Q$ I  k* ?9 P; Q2 \目前NEP-6钱包标准已经完成,以下为NEP-6钱包标准的Github文档(https://github.com/neo-project/proposals/blob/master/nep-6.mediawiki/ J$ u1 ?. A# A4 P2 C: {: E
摘要, W5 s5 `6 J5 H8 E2 ?8 f
NEP-6描述了一个钱包标准,将支持钱包文件在NEO的各种钱包客户端之间共享。$ }4 [4 N: [6 a9 ~- \
目标
; ~' H8 n: z( I" j目前,不同的客户端程序会生成不同的钱包文件。他们有不同的文件格式,不同的存储方式,以及不同的加密方式。用户难以在不同的客户端程序之间迁移,因为钱包文件格式不同。尽管可以通过导出私钥来实现移植,但是对于具有多个私钥的钱包而言,这是非常麻烦的。我们需要一个通用的钱包格式,允许用户安全而轻松地迁移到所有平台上,而无需更改钱包文件或导出私钥。  j3 B0 J1 ~  D# M
基本原理+ c+ {* a6 X2 h9 f1 q
钱包标准应该考虑安全性和跨平台兼容性。为了安全起见,我们要求实现使用NEP-2(https://github.com/neo-project/proposals/blob/master/nep-2.mediawiki)机制来加密或解密私钥。为了达成跨平台要求,我们使用JSON格式来描述钱包文件,以便在每个平台上能够识别钱包文件的内容。7 e9 N% i( u" }# R' \1 j
规范
0 T( b$ j7 _. ?' y  y1 Q' hJSON格式的钱包文件由以下内容构成基本结构
& |1 e, O* e3 o; B{
# t, d# y# C' a& X( B  "name": "MyWallet",
8 a0 I% {6 M* ]! R' \8 K# d3 m  "version": "1.0",; h$ m: d- u! h. y/ ^
  "scrypt": {},$ t! Y$ e. {& h; E5 y8 S
  "accounts": [],1 G; {0 T/ a3 M' Y5 E
  "extra": null! b/ B3 `- S$ X9 u, U
}
* ]7 c/ ~: O6 c4 I9 H& I# Kname 是用户对钱包文件所做的标记。
8 o3 L7 t( ]! \2 }/ v! n6 E$ k  Lversion目前已经修复1.0并将用于未来的功能升级。( T8 S( V0 P6 l! y) {
scrypt 是一个ScryptParameters对象,它描述了用于加密和解密钱包中私钥的SCrypt算法的参数。& \% R: i# g$ [4 U% \
accounts 是一个Account对象的数组,用于描述钱包中每个账户的详细信息。  D7 Q. m. X$ b% }1 |  e
extra 是由客户的实现者定义的用于存储额外数据的对象。这个字段可以null。/ u# }8 S) D$ b8 g
ScryptParameters
% I6 D% S$ }6 o) m: bScryptParameters对象具有以下结构:
; O  O& h9 Z4 v{2 A8 T8 h% m) D! r8 E3 Q. r
  “n”:16384,1 Z2 C) H/ O* G1 Q0 \" _
  “r”:8,
3 ?3 x# a# B; M: q0 T6 k5 O$ p: t, K  “p”:8}
" i, |# |; _- A' C5 zn是定义CPU /内存成本的参数。必须是2 ^ N的值。
- |6 M1 j5 f( or 是一个调整参数。# a5 I& x" H* ^! {2 {
p是一个调整参数(并行参数)。大的p值会增加SCrypt的计算成本,而不会增加内存使用量。
4 O+ Q; Q5 g8 \账户" }# H/ N/ A; V# N* ?4 _
账户对象具有以下结构:
7 W7 c1 v( I. A4 K3 e4 B7 ?+ w{
' u6 ?3 `: b+ X4 O7 s  “address”:“AQLASLtT6pWbThcSCYU1biVqhMnzhTgLFq”,
, s9 u% i" `3 P* [# X0 l9 j  “label”:“MyAddress”,
1 J2 B& ?7 s& B1 O, r1 {  “isDefault”:true,
4 G: j- p8 \; t) S: w* h/ O  “lock”:false,
( o5 l. N/ }* t# R0 A  T* P, g  “key”:“6PYWB8m1bCnu5bQkRUKAwbZp2BHNvQ3BQRLbpLdTuizpyLkQPSZbtZfoxx”,2 ~/ }: y* L& h1 g
  “contract”:{},
. E. x  A7 u5 I7 f* J1 H* ]  u  “extra”:null}8 K" _* ^% a) R( D3 {
address 是帐户的base58编码地址。: i, D2 Q+ X0 j( L8 ~0 _# E. ^
label 是用户对帐户所做的标签。3 B1 X7 o, t% I8 X# q
isDefault 指示该帐户是否是默认的更改帐户。
" R! P$ p! z; s1 tlock指示该帐户是否被用户锁定。客户不应将资金用于锁定的账户。
9 g8 W$ X5 J5 G! S0 m' K* lkey是NEP-2格式的帐户的私钥。该字段可以是null(仅用于监视地址或非标准地址)。
! w& u5 A  s7 |: ?) J/ Dcontract是描述合同细节的合约对象。这个字段可以是null(仅供观看地址)。
9 W! f6 q, n9 bextra是由客户的实现者定义的用于存储额外数据的对象。这个字段可以null。0 |+ i4 T+ P0 h7 s& [. d
合约
/ s( F9 ]9 ~$ @/ C" r" B5 R合约对象具有以下结构:# ~( s2 H9 G* g6 G
{2 ]! y9 ~8 y: x- ^
  "script": "21036dc4bf8f0405dcf5d12a38487b359cb4bd693357a387d74fc438ffc7757948b0ac",
5 S, h* j( E) }! e2 M7 ^8 v% q  "parameters": [],
- j8 l& t& W7 B/ `/ x  "deployed": false3 \9 R; ]9 Z' t$ N& u* R8 y; a+ [
}
( |& ?& ^) t2 x8 K7 b' |; Escript 是合同的脚本代码。如果合同已经部署到区块链,这个字段可以是null。
# T5 g1 U4 ?; p+ uparameters 是一个Parameter对象的数组,它描述了契约函数中每个参数的细节。有关Parameter对象的更多信息,请参阅NEP-3:NeoContract ABI中的说明。(https://github.com/neo-project/proposals/blob/master/nep-3.mediawiki
, T0 P) w3 D1 F8 H0 z$ Adeployed 表示合约是否已经部署到区块链。/ E- v- r0 [( [9 J7 _8 I
旧版兼容性) p, U0 `( C* Y
所有旧格式的钱包应该可以很容易地转换成这个新的JSON格式。如果这些钱包文件包含一些额外的数据,它们可以存储在文件中extra。
2 Z% Q" ?  h7 n6 D& B1 O应用
- _' }5 z% F0 |3 lneo-project / neo:https://github.com/neo-project/neo/blob/master/neo/Implementations/Wallets/NEP6/NEP6Wallet.cs
& l: q$ l0 H/ T# u8 Q1 a; E4 I6 l3 VCityOfZion / neon-js:https://github.com/CityOfZion/neon-js/blob/feature/nep-wallet/src/wallet/Wallet.js
BitMere.com 比特池塘系信息发布平台,比特池塘仅提供信息存储空间服务。
声明:该文观点仅代表作者本人,本文不代表比特池塘立场,且不构成建议,请谨慎对待。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

成为第一个吐槽的人

哈哈笑417 初中生
  • 粉丝

    0

  • 关注

    0

  • 主题

    11