Hi 游客

更多精彩,请登录!

比特池塘 区块链技术 正文

NEP-6钱包标准

哈哈笑417
178 0 0
NEP:NEO Enhancement Proposals,即NEO改进提案,描述了NEO平台的标准,包括核心协议规范,客户端API和合约标准等。最为熟知的是NEP-5代币标准。/ [% t0 o, e! A+ [$ Z* Q
目前NEP-6钱包标准已经完成,以下为NEP-6钱包标准的Github文档(https://github.com/neo-project/proposals/blob/master/nep-6.mediawiki
" C- U; J: r# p# D! X, ~, c9 m摘要) k) M! t8 l( @/ X8 \* e1 w
NEP-6描述了一个钱包标准,将支持钱包文件在NEO的各种钱包客户端之间共享。) T* B' z& F7 ^" e
目标& k* e5 m" ?2 L4 _' p9 C! T
目前,不同的客户端程序会生成不同的钱包文件。他们有不同的文件格式,不同的存储方式,以及不同的加密方式。用户难以在不同的客户端程序之间迁移,因为钱包文件格式不同。尽管可以通过导出私钥来实现移植,但是对于具有多个私钥的钱包而言,这是非常麻烦的。我们需要一个通用的钱包格式,允许用户安全而轻松地迁移到所有平台上,而无需更改钱包文件或导出私钥。) e2 C. O1 m0 D1 A  M) ]2 z
基本原理! P$ t/ r0 {" A
钱包标准应该考虑安全性和跨平台兼容性。为了安全起见,我们要求实现使用NEP-2(https://github.com/neo-project/proposals/blob/master/nep-2.mediawiki)机制来加密或解密私钥。为了达成跨平台要求,我们使用JSON格式来描述钱包文件,以便在每个平台上能够识别钱包文件的内容。  W, b1 }. x5 Q1 l
规范( t+ r0 F& _3 b" v6 H9 Y7 @  V
JSON格式的钱包文件由以下内容构成基本结构; l; B2 @* n, g" W
{$ T! A( y! a5 }3 a( \* {% P9 v  [
  "name": "MyWallet",
1 w2 c5 [2 _% Z0 J7 P' F- p  "version": "1.0",
# B; y8 q$ N* a+ y  "scrypt": {},; k) b3 m; G/ ?# b
  "accounts": [],
+ ^8 N4 h, e; m& A, f5 i  "extra": null+ ]3 `$ f1 C& X- \) F
}
  k$ x( }2 A2 i0 b+ |. T/ Mname 是用户对钱包文件所做的标记。  \- K( p$ Y6 g. J: P* v2 d
version目前已经修复1.0并将用于未来的功能升级。, o! ?6 q: f# C" l# d4 x
scrypt 是一个ScryptParameters对象,它描述了用于加密和解密钱包中私钥的SCrypt算法的参数。
3 d/ m9 R+ A$ Qaccounts 是一个Account对象的数组,用于描述钱包中每个账户的详细信息。
! a2 I/ s9 @! V' i2 e+ `extra 是由客户的实现者定义的用于存储额外数据的对象。这个字段可以null。
0 z( P( n( v: VScryptParameters
4 Q3 m! ~. R3 }% H  W: SScryptParameters对象具有以下结构:4 j8 a; @3 R" ?
{
3 k' |& A5 a( A& g7 p' Y  “n”:16384,* r8 p3 h0 C, \& U% a( b" u# z
  “r”:8,8 ?1 O' J& ~! x( A
  “p”:8}
  F7 U8 M9 ~. Kn是定义CPU /内存成本的参数。必须是2 ^ N的值。7 b  A3 c9 E- r8 Y' }$ w3 t6 `
r 是一个调整参数。
- u9 ]1 \. @1 A9 i# ?- Q! kp是一个调整参数(并行参数)。大的p值会增加SCrypt的计算成本,而不会增加内存使用量。
6 X5 ?! x) _/ p# z( B账户5 z4 R" T$ Q0 l$ G* Q" e, o
账户对象具有以下结构:
, t0 R+ ~3 [# K" S{
/ K# r6 ?3 W; M% n) ?  “address”:“AQLASLtT6pWbThcSCYU1biVqhMnzhTgLFq”,. F$ y  a$ k4 w+ Y1 C
  “label”:“MyAddress”,; G7 Q$ x* L8 D2 J' T, _
  “isDefault”:true,8 x5 X' g* y2 V; M( a
  “lock”:false,
& c$ f" r3 }- O3 B; G  “key”:“6PYWB8m1bCnu5bQkRUKAwbZp2BHNvQ3BQRLbpLdTuizpyLkQPSZbtZfoxx”,: e- _, G% ^4 r( V) L: N( _
  “contract”:{},
6 h9 _9 H& M1 V$ E  ~. y2 g6 H9 J  “extra”:null}
# t" U2 f- ]  X; M6 raddress 是帐户的base58编码地址。7 d" |% J, g/ y
label 是用户对帐户所做的标签。
. k1 Z/ Y( @4 LisDefault 指示该帐户是否是默认的更改帐户。, S( U5 o1 t0 i: E$ V
lock指示该帐户是否被用户锁定。客户不应将资金用于锁定的账户。
+ C4 d, `1 I, e& b& Z, dkey是NEP-2格式的帐户的私钥。该字段可以是null(仅用于监视地址或非标准地址)。) `3 l! G6 b/ O
contract是描述合同细节的合约对象。这个字段可以是null(仅供观看地址)。9 a( M8 |( h, b# l1 K6 M
extra是由客户的实现者定义的用于存储额外数据的对象。这个字段可以null。
* y: \. I4 `' \: u0 m5 e合约) e6 U; b" I1 B
合约对象具有以下结构:
+ d. M4 ?: q# E# A' M{
" q0 X( Y% U% d! s* |" u& b. z  "script": "21036dc4bf8f0405dcf5d12a38487b359cb4bd693357a387d74fc438ffc7757948b0ac",$ b% q% F! {. w! d' F
  "parameters": [],- N# Q! t5 K2 k  F" C6 F( d- b9 r
  "deployed": false
; A- U' I2 E7 [+ c5 h; a7 S4 h/ ]}+ W, [# @% @* E' Q2 Q) v# z
script 是合同的脚本代码。如果合同已经部署到区块链,这个字段可以是null。+ K4 D) n5 b+ T, `
parameters 是一个Parameter对象的数组,它描述了契约函数中每个参数的细节。有关Parameter对象的更多信息,请参阅NEP-3:NeoContract ABI中的说明。(https://github.com/neo-project/proposals/blob/master/nep-3.mediawiki
+ I4 Q2 _- H  t2 x) U2 v8 Rdeployed 表示合约是否已经部署到区块链。
; I7 M7 F# K7 d旧版兼容性
% Q* o. w* S- n4 M6 i所有旧格式的钱包应该可以很容易地转换成这个新的JSON格式。如果这些钱包文件包含一些额外的数据,它们可以存储在文件中extra。9 D' d0 J$ O3 [, o7 O, x) V8 h
应用
. b' L, |4 p4 T; Z! P3 i# u8 Dneo-project / neo:https://github.com/neo-project/neo/blob/master/neo/Implementations/Wallets/NEP6/NEP6Wallet.cs
3 Y( g& M5 u. e( |& l& p, nCityOfZion / neon-js:https://github.com/CityOfZion/neon-js/blob/feature/nep-wallet/src/wallet/Wallet.js
BitMere.com 比特池塘系信息发布平台,比特池塘仅提供信息存储空间服务。
声明:该文观点仅代表作者本人,本文不代表比特池塘立场,且不构成建议,请谨慎对待。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

成为第一个吐槽的人

哈哈笑417 初中生
  • 粉丝

    0

  • 关注

    0

  • 主题

    11