区块链钱包之加密算法简介
Posted 陳英傑
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了区块链钱包之加密算法简介相关的知识,希望对你有一定的参考价值。
(一)区块链钱包之生成助记词
(二)区块链钱包之创建钱包地址
(三)区块链钱包之加密算法简介
(四)区块链钱包之创建比特离线交易(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);
希望我的分享能帮助到大家
以上是关于区块链钱包之加密算法简介的主要内容,如果未能解决你的问题,请参考以下文章