当前位置:   article > 正文

sm2,sm3,sm4国密算法的纯c语言版本,使用于任何嵌入式平台_sm1sm2sm3sm4 c语言代码

sm1sm2sm3sm4 c语言代码

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

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

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

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

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

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

SM2,SM3,SM4的相关文档可以参考如下链接:

http://218.241.108.63/wiki/index.php/首页

SM2,SM3,SM4的C代码如下:使用了openssl开源库。

http://files.cnblogs.com/files/TaiYangXiManYouZhe/Sm2_sm3_sm4_c%E8%AF%AD%E8%A8%80%E5%AE%9E%E7%8E%B0.zip

当使用特定的芯片进行SM1或其他国密算法加密时,若用多个线程调用加密卡的API时,要考虑芯片对于多线程的支持情况。

以下为不使用openssl库的另一种实现方案,基于Miracl大数运算库,可移植。

主要难点就是移植Miracl库,裁剪配置,测试加解密算法。针对不同平台如32位或64位,以及平台的大小端进行配置。

如果Miracl库移植ok了,那么基于Miracl库的sm2算法应没多大问题。

Miracl库里文件较多,且从官网下载的代码,在linux系统上是很容易编译。

但是想用在单片机上,需要一些移植和配置。

只需要包含需要的文件就行了。

以下是编译过程。

 

然后需要新建一个sm2.c文件、sm2.h,用于实现sm2功能函数;一个sm3.c文件、一个sm3.h文件,用于实现sm3功能函数(之所以要增加sm3的功能是因为sm2算法中需要sm3计算hash值功能。
下面给出生成密钥对的示例:

  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #include<string.h>
  4. #include <memory.h>
  5. #include <time.h>
  6. #include "sm2.h"
  7. #define SM2_PAD_ZERO TRUE
  8. #define SM2_DEBUG 0
  9. struct FPECC{
  10. char *p;
  11. char *a;
  12. char *b;
  13. char *n;
  14. char *x;
  15. char *y;
  16. };
  17. /*SM2*/
  18. struct FPECC Ecc256 = {
  19. "8542D69E4C044F18E8B92435BF6FF7DE457283915C45517D722EDB8B08F1DFC3",
  20. "787968B4FA32C3FD2417842E73BBFEFF2F3C848B6831D7E0EC65228B3937E498",
  21. "63E4C6D3B23B0C849CF84241484BFE48F61D59A5B16BA06E6E12D1DA27C5249A",
  22. "8542D69E4C044F18E8B92435BF6FF7DD297720630485628D5AE74EE7C32E79B7",
  23. "421DEBD61B62EAB6746434EBC3CC315E32220B3BADD50BDC4C4E6C147FEDD43D",
  24. "0680512BCBB42C07D47349D2153B70C4E5D7FDFCBFA36EA1A85841B9E46E09A2",
  25. };
  26. unsigned char radom1[] = { 0x4C,0x62,0xEE,0xFD,0x6E,0xCF,0xC2,0xB9,0x5B,0x92,0xFD,0x6C,0x3D,0x95,0x75,0x14,0x8A,0xFA,0x17,0x42,0x55,0x46,0xD4,0x90,0x18,0xE5,0x38,0x8D,0x49,0xDD,0x7B,0x4F };
  27. void PrintBuf(unsigned char *buf, int buflen)
  28. {
  29. int i;
  30. for (i = 0; i < buflen; i++) {
  31. if (i % 32 != 31
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/羊村懒王/article/detail/235034?site
推荐阅读
相关标签
  

闽ICP备14008679号