Hi 游客

更多精彩,请登录!

比特池塘 区块链技术 正文

NEP-6钱包标准

哈哈笑417
190 0 0
NEP:NEO Enhancement Proposals,即NEO改进提案,描述了NEO平台的标准,包括核心协议规范,客户端API和合约标准等。最为熟知的是NEP-5代币标准。+ t  z7 ?! D+ z
目前NEP-6钱包标准已经完成,以下为NEP-6钱包标准的Github文档(https://github.com/neo-project/proposals/blob/master/nep-6.mediawiki' M# j: G% S/ i( L1 F. T
摘要
6 f" y  a' @  b" h, pNEP-6描述了一个钱包标准,将支持钱包文件在NEO的各种钱包客户端之间共享。' N. L1 p/ R) O8 O2 ^1 T/ w
目标
3 J1 p! v0 y. b: F3 m5 ~4 M目前,不同的客户端程序会生成不同的钱包文件。他们有不同的文件格式,不同的存储方式,以及不同的加密方式。用户难以在不同的客户端程序之间迁移,因为钱包文件格式不同。尽管可以通过导出私钥来实现移植,但是对于具有多个私钥的钱包而言,这是非常麻烦的。我们需要一个通用的钱包格式,允许用户安全而轻松地迁移到所有平台上,而无需更改钱包文件或导出私钥。8 E  e6 V/ @4 W0 h- B  ^) ]
基本原理
0 w! I2 J7 ^- z8 X: e钱包标准应该考虑安全性和跨平台兼容性。为了安全起见,我们要求实现使用NEP-2(https://github.com/neo-project/proposals/blob/master/nep-2.mediawiki)机制来加密或解密私钥。为了达成跨平台要求,我们使用JSON格式来描述钱包文件,以便在每个平台上能够识别钱包文件的内容。, @* s5 W. D; y
规范
! C5 u3 S6 J0 h( t4 X! }JSON格式的钱包文件由以下内容构成基本结构$ g+ Y/ g) h2 Y
{
2 G" l: r+ O& S$ D) ^9 o  "name": "MyWallet",
4 o0 S* [# @% N5 u6 ?" V) o  k, ~7 V  "version": "1.0",1 X5 @8 q+ C' g$ u- x
  "scrypt": {},. M3 [6 G* R6 P7 s% e% f; v
  "accounts": [],
5 d3 n) t# X, `/ t% U4 T; V: \  "extra": null3 l8 f9 F7 u. j+ D( |6 I
}9 ?  V. x3 G- _$ k1 E* M) _
name 是用户对钱包文件所做的标记。! R4 V  M( C$ L0 i
version目前已经修复1.0并将用于未来的功能升级。
5 A; x; f( c% z* |scrypt 是一个ScryptParameters对象,它描述了用于加密和解密钱包中私钥的SCrypt算法的参数。0 h$ q% e" L7 b+ p! d3 D
accounts 是一个Account对象的数组,用于描述钱包中每个账户的详细信息。0 @5 {( s! U0 j: @5 z. K
extra 是由客户的实现者定义的用于存储额外数据的对象。这个字段可以null。3 M: ^; h8 i, t+ g# R% X* S
ScryptParameters
5 d8 t  o4 Y5 Z/ r1 r# U. Z8 vScryptParameters对象具有以下结构:8 s) s- C+ K. C* j3 T
{
4 n! ?8 Z4 b' O$ x  “n”:16384,
6 B; K  P/ \7 v+ Z9 N% Q% j+ ~  “r”:8,0 ^. `( U1 O# j: N) }3 V+ s& j. ]
  “p”:8}9 t; c4 `9 N$ I2 |/ X$ w# E
n是定义CPU /内存成本的参数。必须是2 ^ N的值。% P1 t) k! N2 e- Z" ?$ K% o) M* E
r 是一个调整参数。1 M3 R# H! q) k7 z. G0 I, u. l
p是一个调整参数(并行参数)。大的p值会增加SCrypt的计算成本,而不会增加内存使用量。
4 H0 E* [. }8 h# H账户4 C+ M) D0 l: M
账户对象具有以下结构:
/ _: T0 R8 f4 C1 U2 w' t4 o8 W{- N& H+ v' t- B: p
  “address”:“AQLASLtT6pWbThcSCYU1biVqhMnzhTgLFq”,; O6 Z- y% E. H1 @
  “label”:“MyAddress”,
, Y2 }# r; x4 p0 [6 r1 Z8 T  “isDefault”:true,
, g' C4 @$ @0 W  a  “lock”:false,
5 O/ \5 O) U8 h: L2 v  “key”:“6PYWB8m1bCnu5bQkRUKAwbZp2BHNvQ3BQRLbpLdTuizpyLkQPSZbtZfoxx”,8 d7 I4 H+ e9 w$ D
  “contract”:{},5 ]. C" N9 Z; X4 v% E- Y2 j6 L: o8 K
  “extra”:null}
2 m+ F! ^, h/ S" U+ ^" eaddress 是帐户的base58编码地址。
# r8 J% J% g( [+ c# f- V# Wlabel 是用户对帐户所做的标签。
1 U- b6 E  F: h; u, HisDefault 指示该帐户是否是默认的更改帐户。' k9 E9 S2 M" U0 Y, _* j, n
lock指示该帐户是否被用户锁定。客户不应将资金用于锁定的账户。: |' V* @' U5 v, d
key是NEP-2格式的帐户的私钥。该字段可以是null(仅用于监视地址或非标准地址)。+ h( u- [& y) M$ _; ]6 ~* O
contract是描述合同细节的合约对象。这个字段可以是null(仅供观看地址)。
/ |! x$ Q3 {7 Uextra是由客户的实现者定义的用于存储额外数据的对象。这个字段可以null。" [2 j6 ]1 J: s9 Q7 f
合约
4 U1 u" u- J) I8 x. ~! g+ t合约对象具有以下结构:0 E% U- |1 b. c  w
{2 }" i& R1 ^( D
  "script": "21036dc4bf8f0405dcf5d12a38487b359cb4bd693357a387d74fc438ffc7757948b0ac",* ~( ?$ y+ j+ y( k0 ?" m
  "parameters": [],9 w- D2 k; t! j) S. Z5 u% P4 H. v
  "deployed": false
2 |$ ^0 x) \3 q6 M' F+ ?}) D( o+ N8 P, c. {! I2 E: \3 Y
script 是合同的脚本代码。如果合同已经部署到区块链,这个字段可以是null。" c9 v# K' a. j0 \8 i" ]) n- f5 w
parameters 是一个Parameter对象的数组,它描述了契约函数中每个参数的细节。有关Parameter对象的更多信息,请参阅NEP-3:NeoContract ABI中的说明。(https://github.com/neo-project/proposals/blob/master/nep-3.mediawiki! k; V! `, Z8 i9 y
deployed 表示合约是否已经部署到区块链。
& S' q* z, b5 }" o% F0 D旧版兼容性
+ i' ?- R2 W9 ]4 v所有旧格式的钱包应该可以很容易地转换成这个新的JSON格式。如果这些钱包文件包含一些额外的数据,它们可以存储在文件中extra。) L  h6 R' T6 s, W
应用
7 z  t6 U( ?9 t: c2 Zneo-project / neo:https://github.com/neo-project/neo/blob/master/neo/Implementations/Wallets/NEP6/NEP6Wallet.cs
* E! x& I: ^2 [# E5 TCityOfZion / neon-js:https://github.com/CityOfZion/neon-js/blob/feature/nep-wallet/src/wallet/Wallet.js
BitMere.com 比特池塘系信息发布平台,比特池塘仅提供信息存储空间服务。
声明:该文观点仅代表作者本人,本文不代表比特池塘立场,且不构成建议,请谨慎对待。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

成为第一个吐槽的人

哈哈笑417 初中生
  • 粉丝

    0

  • 关注

    0

  • 主题

    11