Hi 游客

更多精彩,请登录!

比特池塘 区块链技术 正文

NEP-6钱包标准

哈哈笑417
202 0 0
NEP:NEO Enhancement Proposals,即NEO改进提案,描述了NEO平台的标准,包括核心协议规范,客户端API和合约标准等。最为熟知的是NEP-5代币标准。. m5 L; b1 N( _! X& q- \& P
目前NEP-6钱包标准已经完成,以下为NEP-6钱包标准的Github文档(https://github.com/neo-project/proposals/blob/master/nep-6.mediawiki
5 x) D# f3 ~! j. ]' D: {$ Q摘要
! k8 C9 y+ L# d' `4 t7 yNEP-6描述了一个钱包标准,将支持钱包文件在NEO的各种钱包客户端之间共享。
; ]# T# N4 k4 H# l5 K目标
% K" P: Z! @6 ^. ]7 e目前,不同的客户端程序会生成不同的钱包文件。他们有不同的文件格式,不同的存储方式,以及不同的加密方式。用户难以在不同的客户端程序之间迁移,因为钱包文件格式不同。尽管可以通过导出私钥来实现移植,但是对于具有多个私钥的钱包而言,这是非常麻烦的。我们需要一个通用的钱包格式,允许用户安全而轻松地迁移到所有平台上,而无需更改钱包文件或导出私钥。
- A$ m& B  B: d/ Z基本原理
( y, n0 Z( K  l钱包标准应该考虑安全性和跨平台兼容性。为了安全起见,我们要求实现使用NEP-2(https://github.com/neo-project/proposals/blob/master/nep-2.mediawiki)机制来加密或解密私钥。为了达成跨平台要求,我们使用JSON格式来描述钱包文件,以便在每个平台上能够识别钱包文件的内容。0 y( ?; n" C# B1 U/ e
规范
' w! Z8 l( F8 V# [+ H* x& ?4 I% F0 K# PJSON格式的钱包文件由以下内容构成基本结构
+ K& T& |* E4 q: ^! l{/ f9 ^. L& f6 C- B9 i
  "name": "MyWallet",6 k6 z0 I; C  @% E
  "version": "1.0",
5 j+ `/ ~% @( ?% _  Q2 B  "scrypt": {},8 Q& ~) h' S& a6 d9 V( ]2 [2 _! ^
  "accounts": [],+ q6 Q7 {& s% [, X; _3 W
  "extra": null
4 H5 E" [# S5 n9 M}
7 C7 t$ Y& Y- d7 Z  H% \: h5 O9 C* Kname 是用户对钱包文件所做的标记。
0 J& o5 H1 i3 d6 M; _+ J" @1 kversion目前已经修复1.0并将用于未来的功能升级。9 `. I9 H; p; c: ^0 ?
scrypt 是一个ScryptParameters对象,它描述了用于加密和解密钱包中私钥的SCrypt算法的参数。
. K  S: }/ o6 E7 c7 O; |5 B3 Qaccounts 是一个Account对象的数组,用于描述钱包中每个账户的详细信息。* B4 S3 d4 E& P5 w5 l8 _3 `( \
extra 是由客户的实现者定义的用于存储额外数据的对象。这个字段可以null。8 s' e8 b+ `; L
ScryptParameters
* ]. W& W5 Z5 _' f; |& B( D# sScryptParameters对象具有以下结构:7 \; ?, M. E5 D/ M
{
% S' t* G3 P5 Q  “n”:16384,# Q' [8 \4 N6 C$ W! [8 m' E  x
  “r”:8,/ H# T' m1 x* Y+ k. `3 K7 a! r
  “p”:8}
: O* s3 G5 `) l! W* Z8 v; Gn是定义CPU /内存成本的参数。必须是2 ^ N的值。5 u% S4 u* n! z, y4 E
r 是一个调整参数。% ]( \: e; K" o
p是一个调整参数(并行参数)。大的p值会增加SCrypt的计算成本,而不会增加内存使用量。& k# S: F, ^7 f9 r
账户4 b% s# f. u! M0 y4 _1 ]
账户对象具有以下结构:
+ B1 \2 L: U4 _3 I  P{+ ~: z# r, s7 |' ?# \5 p% Z6 C6 L
  “address”:“AQLASLtT6pWbThcSCYU1biVqhMnzhTgLFq”,
2 E& e( Q9 J# f4 q7 H  I, c: ?; B  “label”:“MyAddress”,# [* h: x6 M2 l' b2 c7 h. L
  “isDefault”:true,
6 |9 O( ]1 P* V% k  “lock”:false,2 z" Y% Y1 r  d9 i+ f
  “key”:“6PYWB8m1bCnu5bQkRUKAwbZp2BHNvQ3BQRLbpLdTuizpyLkQPSZbtZfoxx”," o& a, w4 j5 i. [1 l( j
  “contract”:{},
( H4 X+ |/ R  \  “extra”:null}% A5 }) v, B" t4 ~2 z! v: \3 I
address 是帐户的base58编码地址。; g0 A: A) M( H1 U, n( z
label 是用户对帐户所做的标签。
  r. k3 \* t4 M( {isDefault 指示该帐户是否是默认的更改帐户。
' l" t4 l8 i$ j. [% ?+ Flock指示该帐户是否被用户锁定。客户不应将资金用于锁定的账户。
' H- ~7 V3 Z. R5 B) jkey是NEP-2格式的帐户的私钥。该字段可以是null(仅用于监视地址或非标准地址)。/ g/ P& L; p: t; C+ B+ x: M
contract是描述合同细节的合约对象。这个字段可以是null(仅供观看地址)。
6 ]' ~, Y6 w2 J! K" Y* @, w& ?extra是由客户的实现者定义的用于存储额外数据的对象。这个字段可以null。& q. d4 ^: ?  a0 X6 {+ X
合约
* _1 g4 ]8 C2 Z9 J* w. r* z合约对象具有以下结构:( L1 X& p$ e6 B* i) f. G3 s' l- q: K
{
# G2 ~; G$ n* h  S0 J% e5 \  "script": "21036dc4bf8f0405dcf5d12a38487b359cb4bd693357a387d74fc438ffc7757948b0ac",
/ y' Z$ V, p. \8 @; {! S  "parameters": [],( P) p- a- `5 H8 ?5 a0 H
  "deployed": false
3 E5 I# h# q3 b& n2 ?* S: S}
2 y3 O* k( ?6 L( @script 是合同的脚本代码。如果合同已经部署到区块链,这个字段可以是null。. r2 U- f# ], w' f3 ^8 o# |$ k
parameters 是一个Parameter对象的数组,它描述了契约函数中每个参数的细节。有关Parameter对象的更多信息,请参阅NEP-3:NeoContract ABI中的说明。(https://github.com/neo-project/proposals/blob/master/nep-3.mediawiki
( g. ^6 T, E% x* o- ~, L& h( ?deployed 表示合约是否已经部署到区块链。
% {. w' W# V) R  M, c旧版兼容性
2 ?( r1 \, [2 y2 z所有旧格式的钱包应该可以很容易地转换成这个新的JSON格式。如果这些钱包文件包含一些额外的数据,它们可以存储在文件中extra。
0 R: A6 c3 y- D! P1 l( Q# D+ S0 I应用4 o( Q- d! @& J, f+ y: H. U7 I
neo-project / neo:https://github.com/neo-project/neo/blob/master/neo/Implementations/Wallets/NEP6/NEP6Wallet.cs& @: J+ {+ x, }9 y9 V; Q1 n9 e
CityOfZion / neon-js:https://github.com/CityOfZion/neon-js/blob/feature/nep-wallet/src/wallet/Wallet.js
BitMere.com 比特池塘系信息发布平台,比特池塘仅提供信息存储空间服务。
声明:该文观点仅代表作者本人,本文不代表比特池塘立场,且不构成建议,请谨慎对待。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

成为第一个吐槽的人

哈哈笑417 初中生
  • 粉丝

    0

  • 关注

    0

  • 主题

    11