国密算法

Python027

国密算法,第1张

国密即国家密码局认定的国产密码算法。主要有SM1,SM2,SM3,SM4。密钥长度和分组长度均为128位。

SM1 为对称加密。其加密强度与AES相当。该算法不公开,调用该算法时,需要通过加密芯片的接口进行调用。

SM2为非对称加密,基于ECC。该算法已公开。由于该算法基于ECC,故其签名速度与秘钥生成速度都快于RSA。ECC 256位(SM2采用的就是ECC 256位的一种)安全强度比RSA 2048位高,但运算速度快于RSA。

国家密码管理局公布的公钥算法,其加密强度为256位

SM3 消息摘要。可以用MD5作为对比理解。该算法已公开。校验结果为256位。

SM4 无线局域网标准的分组数据算法。对称加密,密钥长度和分组长度均为128位。

由于SM1、SM4加解密的分组大小为128bit,故对消息进行加解密时,若消息长度过长,需要进行分组,要消息长度不足,则要进行填充。

分组密码算法(DES和SM4)、将明文数据按固定长度进行分组,然后在同一密钥控制下逐组进行加密,

公钥密码算法(RSA和SM2)、公开加密算法本身和公开公钥,保存私钥

摘要算法(SM3 md5) 这个都比较熟悉,用于数字签名,消息认证,数据完整性,但是sm3安全度比md5高

总得来说国密算法的安全度比较高,2010年12月推出,也是国家安全战略,现在银行都要要求国际算法改造,要把国际算法都给去掉

C 语言实现

https://github.com/guanzhi/GmSSL/

Go 语言

https://github.com/tjfoc/gmsm

https://github.com/ZZMarquis/gm

Java 语言

https://github.com/PopezLotado/SM2Java

Go语言实现,调用 gmsm

如果是说底层公链开发的话,是很难的。

底层公链其实就是区块链世界的基础设施,相当于我们现在的手机系统。而一个个商业化的区块链项目(Dapp)就类似于跑在手机上的APP,可以说一切的Dapp都要基于底层公链运行,就像玩手机游戏需要在安卓系统或者IOS系统上一样,而现在的主流手机系统也只有这两个,这就已经证明了开发一个区块链底层公链的难度了。

现在的区块链的“基础设施”还不够发达。典型的例子就是去年一个基于以太坊的应用「CryptoKitties」。这是一个通过区块链进行云养猫的游戏应用,一上线就十分火爆,也直接导致以太坊几乎崩溃。CryptoKitties上线短短几天,发生了45000多次交易,近600万美元的交易额,而以太坊的每秒处理交易量(TPS)只有30-40,导致以太坊网络严重拥堵,再一次证明了区块链的不可能三角:去中心化、安全性、效率。

区块链的核心是技术。在基础设施没有搭建好之前,所有的花团锦簇的区块链项目都是空中楼阁。目前区块链底层公链比较突出的是北京的Conflux项目,姚期智院士作为首席科学家,来自清华姚班、多伦多大学等世界级高校的大牛技术团队,在不牺牲去中心化和安全性的条件下,将TPS提高到3000次。就在1周前,Conflux项目组在一周年的测试实验上,用25分36秒跑完了以太坊7个月的交易数据,这在世界上都是顶尖的水平。