(三)区块链钱包之加密算法简介

10 篇文章 0 订阅
6 篇文章 0 订阅

(一)区块链钱包之生成助记词
(二)区块链钱包之创建钱包地址
(三)区块链钱包之加密算法简介
(四)区块链钱包之创建比特离线交易(BTC交易)
(五)区块链钱包之创建以太坊交易(ETH交易)

钱包作为用户隐私数据不可以对其进行直接保存,更不可以上传服务器,所以如何处理来管理钱包需要慎重。

当用户创建完钱包之后,钱包相当于用户的手机,如果不想别人看你手机内容需要密码;其实用户对钱包的操作都基于助记词,助记词就是密码,当你拥有助记词就相当于你拥有了操作钱包的权限,但是助记词不容易记,而且每次输入太繁琐,我们可以设置钱包密码来代替助记词的功能,支付密码为更简便的6位数字来代替钱包密码。

1、钱包密码进行hash256,结果作为Aes的key来对助记词进行AES加密,结果保存手机中;
2、支付密码进行BCrypt保存;
3、支付密码进行hash256,结果作为Aes的key来对钱包密码加密,结果保存;

在进行交易的时候根据用户输入的支付密码进行反解来得到助记词,用助记词来获取ECKey对交易进行签名。

AES

对称加密方式,通过key对明文加密,通过key可以对密文解密成明文。

BCrypt

单项hash加密算法,每次hash出来的结果不同,但是可以判断密文是否来自明文。

/* 
 * 加密方法
 * 此方法可能导致程序挂起,可以放在子线程执行。
 */
Bcrypt.hashpw(password, BCrypt.gensalt());

/*
 * 验证密码正确性
 * 此方法内部也调用了hashpw()方法。
 */
Bcrypt.checkpw(password, hashed);

在这里插入图片描述

希望我的分享能帮助到大家
在这里插入图片描述

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值