密码学在区块链的应用非常广泛,可分为3类:对称加密算法、非对称加密算法和哈希散列算法。常见的方法有: Merkle tree 哈希树算法,椭圆曲线算法,SHA-256算法,Base58编码。作用有:通过hash算法快速查找;对明文进行加解密;对信息进行签名以及验证;产生数字证书;生成账户地址等。
密码学的历史悠久,古时候主要应用于军事机密的传送,如“口令”,“暗号”等。在1970年之前,密码学的应用范畴大部分还是在政府层面,直到标准加密系统-数据加密标准和非对称加密算法的发明,密码学才逐步被深入应用在各个领域。
1 密码学的发展历程
密码学的发展大致可以分为三个阶段:古典密码学->现代密码学->公钥密码学
1.古典密码学:这阶段的核心密码学思想主要为代替和置换。代替就是将明文每个字符替换成另外一种字符产生密文,接收者根据对应的字符替换密文就得到明文了。置换就是将明文的字符顺序按照某种规则打乱。
2.现代密码学:这阶段的发展主要是对称加密算法。对称加密是发送方使用某种公开的算法使用密钥对明文进行加密,接收方使用之前发送方给予的密钥对密文进行解密得到明文。
3.公匙密码学:这个阶段的发展主要是非对称加密算法。非对称加密的原理是公钥加密,私钥解密。它的实现过程是A通过某种算法产生一对密钥,分别是公钥和私钥,然后将公钥公开。B想发送信息给A,就使用A的公钥对明文进行加密产生密文并发送给A。A接收到密文后,用自己的私钥对密文进行解密,得到明文。
对称加密解密的示意图如下:
对称性密码系统就是加密和解密用的是同一把钥匙。
例如Alice要快递一个礼物给自己的朋友Bob。因为快递过程中怕有人会打开将礼物取走,于是Alice用了一把锁,并将钥匙提前给了Bob,Bob收到礼物后用之前Alice给他的钥匙将礼物打开。
用这种加密方式保证了礼物的安全,对于一些保密要求不是特别高的物件和信息,这种方式就可以了。现在问题来了,Alice想让Bob在收到礼物后给她一个短信确认。我们可能会想短信确认很方便啊。问题是Alice怎么确认发信息的人就是Bob本人。
而且,对于对称性密码系统,需要准备的密码数量通常很多。比如说我们有个组织有100个人,这100个人之见要相互赠送礼物,这时候我们要准备100*99/2=4950把不同的钥匙,如果组织人数更多,那密码个数更恐怖N(N-1)/2。
非对称加密解密的示意图如下:
非对称性密码系统是加密和解密的过程,所用的是不同的钥匙。
例如Alice打算给Bob一份礼物,她只要拿到Bob的公钥将礼物锁好,然后寄给Bob,Bob收到礼物后用自己的私钥打开礼物。
每个人有专属的公钥和私钥密码对。公钥对外开放,私钥自己保存。即使组织有100个人,那么私钥的数量也只是100个。
交易信息查询方法:
1,hash数列(精准)
2,发送方地址(需要核对信息)
3,接收方地址(需要核对信息)