愿码(ChainDesk.CN):EOS钱包开发 五使用cleos工具管理账号权限_账户权重之和须大于等于阀值-程序员宅基地

技术标签: 区块链  EOS  


在上一篇文章中,我们创建了一个新钱包并导入了一对公私钥,但是该钱包中并没有账号,在EOS区块链中创建账号是很扯蛋的事,必须使用已有的EOS账号才能创建新的EOS账号,使创建账号的时候便于扣费,因为创建的账号数据会占用区块链生产节点的内存资源,所以每创建一个EOS新账号都需要其他EOS账号消耗一定量的EOS来帮忙创建。那么我们找谁来创建呢?谁又有EOS账号呢?

  • EOS主网中,最初始的EOS账号由EOS主网在映射阶段创建完成。
  • 在本地网络中,最初始的EOS账号在系统启动的时候就自动被创建了一个超级用户——eosio。

我们是在本地网络中进行开发,所以我们将使用eosio超级账号去创建新账号。

一、创建账号

下面我们将要创建账号lixu

我们钱包中是没有eosio账号的,但是可以通过命令行工具cleos去创建账号。在环境搭建的一篇文章的我们在default钱包中已经能够使用eosio账号了,创建的新账号由钱包应用程序中新建的mywallet1钱包中的私钥对控制,公钥为EOS8RPRLzktF2fHH14R3HDcsvVnq9m2XGQUiZ2EjvneqqkuFZdqDy,私钥是5HrqHYGMPn36zk3mqNU1tmuQrD2SQHxCGdCMjBFBkJ815tjxmS2

 

第一步:我们须解锁eosio账号所在的钱包。

image.png

 

 

第二步:查看创建账号命令的说明cleos create account

image.png

根据输出可知:

  • 创建账号需要购买ram、带宽,在本地网络中可以不用购买,无限制的使用资源,在稍后我们验证这个说法。
  • 创建账号的完整命令是cleos create account [OPTIONS] creator name OwnerKey [ActiveKey]
  • Positionals结构中包含四个字断:
  • creator TEXT(必填):创建者账号的名称。
  • name TEXT(必填) :新账号的名称。
  • OwnerKey TEXT(必填):新账号的owner权限的公钥。
  • ActiveKey TEXT(可选):新账号的active权限的公钥,默认与owner权限的公钥一致。
  • Options结构中有很多可选参数,介绍一下比较常用的几个:
  • -d:是不广播到网络。
  • -j:是返回为json格式的数据。
  • -s:是交易数据不经过签名。
  • -p:是指定签名的账号以及权限,默认是active权限。
  • -h:是帮助命令。

第三步:我们创建的第一个账号的owner权限和active权限都使用前面的这一对公私钥控制即可,新账号名称为lixu,所以创建账号的完整命令如下:

image.png

 

 

二、新增权限

下面我们将要新增账号lixuvoting权限。

现在账号liux的有自带的两个原生权限:owner权限与active权限,owner拥有很多功能给的操作权限,如:转账、投票、购买ram等等,我们可以将其中一个或多个功能,比如将投票权任命给一个自定义权限voting。那么无须owner、active权限所对应的私钥对投票操作进行签名,单单通过voting权限所对应的私钥对投票操作进行签名便可完成投票操作。

 

第一步:查看账号lixu的权限分配,使用命令cleos get account lixu

image.png

 

可知在本地网络中可以无限制的使用资源,我们现在只关心“permissions”的内容,在后面我们会切换到真实的测试网络中开发,然后重点介绍后面各项的含义与作用。

第二步:查看新增权限命令的说明cleos set account permission

image.png

 

根据输出可知:

  • 创建账号的完整命令是cleos set account permission [OPTIONS] account permission authority [parent]
  • Positionals结构中包含四个字断:
  • account TEXT(必填):设置/删除权限的帐户。
  • permission TEXT(必填) :设置/删除权限的权限名称。
  • authority TEXT(必填):若删除则是NULL、创建/更新则是公钥、JSON字符串或者文件名。
  • parent TEXT(可选):该权限的父权限的权限名,默认为active。
  • Options结构中的可选参数与之前介绍的一样,

第三步:新建一对公私钥控制voting权限

image.png

 

第五步:新增权限后再次查看账号lixu的权限分配。

到此我们已经完成了给一个账号新建权限并指定控制的公钥的功能。

 

三、新增权限控制的主体

1. 如何新增权限控制的主体

新增权限控制的主体有三种方式:公私钥对、账号、延迟,这里我们只介绍常见的前面两种。

下面我们新增账号lixuactive权限控制的主体。

初始时每个权限只有一个主体(一对公私钥),我们可以修改权限由多个主体控制,这样做的目的在于让多个主体共同控制一个权限的功能,即多签,只有当主体(一对公私钥)的权重大于等于阀值才能拥有该权限进行相应操作。

修改权限控制的主体需要传递的是json字符串或者json文件,那么json字符串的数据结构是怎么样的呢?如下:

image.png

 

每个字断的解释如下:

image.png

 

我们可以选择性的设置权限的控制权,但是必须要按照如下规则进行修改:

  • 严格按照上面的json数据结构设置
  • 修改的公钥、账号必须按照从小到大进行排序,如:EOS67Z…需在EOS7dm签名。
  • 所有控制体的权重的和必须大于等于阀值。

2. 新增权限控制的主体:公私钥对

第一步:新建一对公私钥作为active权限的另一个主体。

image.png

 

第三步:新增权限控制的主体后再次查看账号lixu的权限分配。

image.png

 

现在两个主体都可以操作active权限的功能,因为它们的权重等于阀值。

3. 新增权限控制的主体:账号

使用tester的owner权限作为账号lixu的active权限的一个主体,分配的权重仍为1,完整的命令如下

image.png

四、修改阀值

接下来我们通过修改账号lixuactive权限的阀值为2,实现多签的功能。

第一步:测试账号lixuactive权限的

EOS8RPRLzktF2fHH14R3HDcsvVnq9m2XGQUiZ2EjvneqqkuFZdqDy主体是否拥有它的(active)功能。

image.png

 

因此,现在必须同时拥有active的两个主体才能使用active权限的功能,因为两个主体的权重分别为1,加起来才等于acrive权限的阀值2。现在有哪些办法可以使用active权限呢?

  • 使用-p lixu@owner签名。
  • 修改改主体的权重大于等于active权限的阀值。
  • 将另外个私钥导入到该钱包。

 

五、修改权重

下面我们修改

EOS8RPRLzktF2fHH14R3HDcsvVnq9m2XGQUiZ2EjvneqqkuFZdqDy

主体的权重为2。

现在该主体的权重为1不能使用active的功能,所以将它的权重改为与active的阀值一样,以使它能使用该权限。但是想要修改active的权限,需要active签名,或者它的父权限owner签名,那么只好使用owner签名了,否则修改失败。

完整的命令如下:

image.png

 

此时active的阀值为2,另外一个主体EOS7dmF...权重还是1,不能单独使用active,必须与主体

EOS8RPR...共同签名方可使用。

 

六、多重签名

前面的步骤都是单签名完成的操作,如何实现多签名呢?就是使用多个私钥一起对交易进行签名。那么下面我们重新配置一下该账号的active权限。

现在active的三个主体的权重都小于阀值,不能单独使用active权限。上面介绍了有三种办法可以使用active权限,第一、二种已经使用过了,并且不是没有使用到多重签名,接下来我们使用最后种方式——将另外个私钥导入到该钱包来实现多重签名。

需要导入tester的owner权限的私钥到mywallet1钱包。现在mywallet1钱包就拥有权重为2的主体

EOS8RPR...,与权重为1的主体test的owner权限,主体权重就一共为3等于了active阀值,然后就可以使用多重签名操作active权限了。

image.png

 

七、总结

每个权限都会有一个阀值,初始时为1。权限下的每对公私钥都会有一个权重,初始时每个权限只有一对公私钥且权重为1。后续账户可以修改权限的阀值,可以对每个主体(即每对EOS公私钥或账号)分配不同的权重,还可以修改权限由多个主体管理。只有当公私钥的权重大于等于阀值才能拥有该权限进行相应操作。

版权声明:博客中的文章版权归博主所有,未经授权禁止转载,转载请联系作者(微信:lixu1770105)取得同意并注明出处。

本文地址: https://chaindesk.cn/witbook/2/22

 


愿码(ChainDesk.CN)——连接每个程序员的故事

“愿码”以线上社区线下实战型人才加速器相结合,立志打造全球最大的IT实战型多元化复合型人才生态圈。

免费技术交流群:263270946

技术提升、快速转型请关注微信公众号:愿码


 

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/weixin_43970764/article/details/88943484

智能推荐

使用nginx解决浏览器跨域问题_nginx不停的xhr-程序员宅基地

文章浏览阅读1k次。通过使用ajax方法跨域请求是浏览器所不允许的,浏览器出于安全考虑是禁止的。警告信息如下:不过jQuery对跨域问题也有解决方案,使用jsonp的方式解决,方法如下:$.ajax({ async:false, url: 'http://www.mysite.com/demo.do', // 跨域URL ty..._nginx不停的xhr

在 Oracle 中配置 extproc 以访问 ST_Geometry-程序员宅基地

文章浏览阅读2k次。关于在 Oracle 中配置 extproc 以访问 ST_Geometry,也就是我们所说的 使用空间SQL 的方法,官方文档链接如下。http://desktop.arcgis.com/zh-cn/arcmap/latest/manage-data/gdbs-in-oracle/configure-oracle-extproc.htm其实简单总结一下,主要就分为以下几个步骤。..._extproc

Linux C++ gbk转为utf-8_linux c++ gbk->utf8-程序员宅基地

文章浏览阅读1.5w次。linux下没有上面的两个函数,需要使用函数 mbstowcs和wcstombsmbstowcs将多字节编码转换为宽字节编码wcstombs将宽字节编码转换为多字节编码这两个函数,转换过程中受到系统编码类型的影响,需要通过设置来设定转换前和转换后的编码类型。通过函数setlocale进行系统编码的设置。linux下输入命名locale -a查看系统支持的编码_linux c++ gbk->utf8

IMP-00009: 导出文件异常结束-程序员宅基地

文章浏览阅读750次。今天准备从生产库向测试库进行数据导入,结果在imp导入的时候遇到“ IMP-00009:导出文件异常结束” 错误,google一下,发现可能有如下原因导致imp的数据太大,没有写buffer和commit两个数据库字符集不同从低版本exp的dmp文件,向高版本imp导出的dmp文件出错传输dmp文件时,文件损坏解决办法:imp时指定..._imp-00009导出文件异常结束

python程序员需要深入掌握的技能_Python用数据说明程序员需要掌握的技能-程序员宅基地

文章浏览阅读143次。当下是一个大数据的时代,各个行业都离不开数据的支持。因此,网络爬虫就应运而生。网络爬虫当下最为火热的是Python,Python开发爬虫相对简单,而且功能库相当完善,力压众多开发语言。本次教程我们爬取前程无忧的招聘信息来分析Python程序员需要掌握那些编程技术。首先在谷歌浏览器打开前程无忧的首页,按F12打开浏览器的开发者工具。浏览器开发者工具是用于捕捉网站的请求信息,通过分析请求信息可以了解请..._初级python程序员能力要求

Spring @Service生成bean名称的规则(当类的名字是以两个或以上的大写字母开头的话,bean的名字会与类名保持一致)_@service beanname-程序员宅基地

文章浏览阅读7.6k次,点赞2次,收藏6次。@Service标注的bean,类名:ABDemoService查看源码后发现,原来是经过一个特殊处理:当类的名字是以两个或以上的大写字母开头的话,bean的名字会与类名保持一致public class AnnotationBeanNameGenerator implements BeanNameGenerator { private static final String C..._@service beanname

随便推点

二叉树的各种创建方法_二叉树的建立-程序员宅基地

文章浏览阅读6.9w次,点赞73次,收藏463次。1.前序创建#include<stdio.h>#include<string.h>#include<stdlib.h>#include<malloc.h>#include<iostream>#include<stack>#include<queue>using namespace std;typed_二叉树的建立

解决asp.net导出excel时中文文件名乱码_asp.net utf8 导出中文字符乱码-程序员宅基地

文章浏览阅读7.1k次。在Asp.net上使用Excel导出功能,如果文件名出现中文,便会以乱码视之。 解决方法: fileName = HttpUtility.UrlEncode(fileName, System.Text.Encoding.UTF8);_asp.net utf8 导出中文字符乱码

笔记-编译原理-实验一-词法分析器设计_对pl/0作以下修改扩充。增加单词-程序员宅基地

文章浏览阅读2.1k次,点赞4次,收藏23次。第一次实验 词法分析实验报告设计思想词法分析的主要任务是根据文法的词汇表以及对应约定的编码进行一定的识别,找出文件中所有的合法的单词,并给出一定的信息作为最后的结果,用于后续语法分析程序的使用;本实验针对 PL/0 语言 的文法、词汇表编写一个词法分析程序,对于每个单词根据词汇表输出: (单词种类, 单词的值) 二元对。词汇表:种别编码单词符号助记符0beginb..._对pl/0作以下修改扩充。增加单词

android adb shell 权限,android adb shell权限被拒绝-程序员宅基地

文章浏览阅读773次。我在使用adb.exe时遇到了麻烦.我想使用与bash相同的adb.exe shell提示符,所以我决定更改默认的bash二进制文件(当然二进制文件是交叉编译的,一切都很完美)更改bash二进制文件遵循以下顺序> adb remount> adb push bash / system / bin /> adb shell> cd / system / bin> chm..._adb shell mv 权限

投影仪-相机标定_相机-投影仪标定-程序员宅基地

文章浏览阅读6.8k次,点赞12次,收藏125次。1. 单目相机标定引言相机标定已经研究多年,标定的算法可以分为基于摄影测量的标定和自标定。其中,应用最为广泛的还是张正友标定法。这是一种简单灵活、高鲁棒性、低成本的相机标定算法。仅需要一台相机和一块平面标定板构建相机标定系统,在标定过程中,相机拍摄多个角度下(至少两个角度,推荐10~20个角度)的标定板图像(相机和标定板都可以移动),即可对相机的内外参数进行标定。下面介绍张氏标定法(以下也这么称呼)的原理。原理相机模型和单应矩阵相机标定,就是对相机的内外参数进行计算的过程,从而得到物体到图像的投影_相机-投影仪标定

Wayland架构、渲染、硬件支持-程序员宅基地

文章浏览阅读2.2k次。文章目录Wayland 架构Wayland 渲染Wayland的 硬件支持简 述: 翻译一篇关于和 wayland 有关的技术文章, 其英文标题为Wayland Architecture .Wayland 架构若是想要更好的理解 Wayland 架构及其与 X (X11 or X Window System) 结构;一种很好的方法是将事件从输入设备就开始跟踪, 查看期间所有的屏幕上出现的变化。这就是我们现在对 X 的理解。 内核是从一个输入设备中获取一个事件,并通过 evdev 输入_wayland

推荐文章

热门文章

相关标签