首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

SM4加密算法原理以及C语言实现

文章目录 一.算法原理描述 1.密钥及密钥参量: 2.加密算法: 3.解密算法: 4.密钥扩展算法: 二.C语言算法实现 .h部分代码: .c部分代码: 一.算法原理描述 SM4分组密码算法是一个迭代分组密码算法...但可以自行补足字节来做到任意长度字节数据加密,后面C语言实现部分有所体现) 1.密钥及密钥参量: SM4分组密码算法的加密密钥长度为128b,表示为MK=(MK0,MK1,MK2,MK3),其中MKi(...2.加密算法: SM4加密算法由32次迭代运算和1次反序变换R组成 设明文输入为(X0,X1,X2,X3)∈(Z232)4,密文输出为(Y0,Y1,Y2,Y3)∈(Z232)4,轮密钥为rki∈Z232...加密算法的运算过程如下。...二.C语言算法实现 .h部分代码: #ifndef _SM4_H_ #define _SM4_H_ #include #include #include <string.h

2.6K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Mac电脑C语言开发的入门帖

    C语言 C语言可说是电脑环境中的“镇国神器”,从发明至今,虽然C语言的使用者缓慢的减少,但从当前市场应用情况看,尚无一台电脑能够摆脱C语言的支撑而生存。...最后就是近几年,随着物联网、嵌入式开发的进展,效率最高、资源需求最少的C语言,又成为了很多项目的不二选择。 Mac电脑作为类Unix类操作系统的代表,C语言也是天生具备的。...很多Mac电脑即便不用于软件开发,也会因为各种免费开源软件的使用,在依赖包中自动安装了gcc的支持,从而具备了C语言的开发环境。...Mac的命令行C语言开发工具主要有两种,clang及gcc,前者是苹果官方推荐的,Xcode也使用Clang进行编译。后者则是GNU开源社区推荐的,并且被大多数linux支持。...此外这里使用gcc进行了c语言程序的编译,但并不一定真的是gcc系统,在Mac电脑上默认是使用clang系统,只是为了兼容也伪装成了gcc的调用方式而已。

    1.8K50

    mac电脑的terminal里该如何运行c语言

    若要在 Mac 的终端中编译并运行 C 源代码,你首先需要安装 Command Line Tools,里面包含有 GCC 编译器。安装方法为: 打开终端,输入 gcc。...安装完成后,定位至你需要编译的 C 源代码所在目录,即使用 cd 命令,例如我现在在根目录下,我的 C 代码位于 ~/Desktop/Self/C 文件夹中,我便可以在终端中输入以下命令,来跳转到我 C...代码的文件夹: 1 cd Desktop/Self/C 效果如图: ?...例如,我要编译的文件叫 dot.c,那么就在终端中输入 1 gcc -Wall -g -o dot dot.c 其中,-Wall 代表编译器在编译过程中会输出警告信息(Warning...我这里是 dot.c。注意加上后缀 .c。 输入完毕后按回车,如果编译没有任何问题,不会有任何提示。如果有问题,编译器会提示你问题是什么,在源代码的什么位置。如图所示: ?

    5.7K20

    SM4加密算法(JAVA语言实现)

    1、SM4算法简介 中国国家密码管理局于2006年1月6日发布第7号公告,将我国无线局域网产品的加密算法确定为SM4算法(原SMS4)。这是国内官方公布的第一个商用密码算法。...加密算法与密钥扩展算法都采用32轮非线性迭代结构。解密算法与加密算法的结构相同,只是轮密钥的使用顺序相反,解密轮密钥是加密轮密钥的逆序。...加密轮密钥的使用顺序是 , 而解密时密钥的使用顺序为加密时候的反序: 2、密码算法程序各模块详细设计 2.1 核心模块主要实现算法的流程 图1 SM4加密算法流程示意图 图2 SM4密钥扩展算法流程图...3.2 SM4加密算法核心代码 /********************************** * 功能说明:SM4加密算法实现 * 参数说明:Input 输入的明文 * Output.../ 4] >>> 8 & 0xFF); Output[j + 3] = (byte) (x[3 - j / 4] & 0xFF); } } 3.3 SM4解密算法核心代码 SM4的解密算法与加密算法类似

    1.2K10

    C++】C 语言C++ 语言的关系 ( C 语言发展 | C 语言缺陷 | C 语言 + 面向对象 + 高级语言特性 | C++ 语言增加内容 | C 语言C++ 语言应用场景 )

    一、C 语言发展 C 语言 被开发之前 并 没有经过 缜密 的 设计 , 而是在 使用过程中 逐渐完善的 ; C 语言发展经过如下阶段 : 初始阶段 : 1972年至1978年 , C语言 初步形成 ,...C99 , C11 , C17 等标准 , 以满足新的编程需求 ; 二、C 语言缺陷 C 语言有如下缺陷 : C 语言 没有经历过 缜密的 设计过程 , 都是根据需求逐渐完善的 , 出现了很多缺陷和漏洞...语言 , 如 : Objective-C , 主要用于 Mac 软件和 iPhone / iPad 软件开发 ; C++ , 用途广泛 , Windows / Linux 都可以使用 C++ 语言 ;...2、C 语言C++ 语言关系 C 语言C++ 语言 并 不是 竞争关系 ; C++ 语言 是 以 C 语言为基础 的 加强版本编程语言 , 可以看作是更好的 C 语言 , 在 C++ 语言...中 , 可以使用 C 语言语法 , 对 C 语言完全兼容 ; C++ 语言 包含 C 语言 , 在 C++ 代码中可以使用 C 语言的语法 , 但是在 C 语言中不能使用 C++ 的语法 ; 3、C++

    27820

    C语言】初识C语言(常见的C语言概念)

    一.C语言是什么?...语言大致可以分为自然语言和计算机语言,自然语言就是人与人日常交流的语言,如汉语、英语、日语等等,计算机语言又可以分为机器语言、汇编语言、高级语言C语言就是一个高级语言 机器语言:就是由二进制01组合起来的计算机可以直接识别的程序语言是一种面向机器的语言...,比起低级语言易懂易学,可移植性好,编程效率高,但是执行效率没有低级语言高,需要经过编译或解释,C语言就是采用编译的一种高级语言 二.为什么选择C语言 C语言常年霸榜各类高级语言前三,属于基础必学的语言...,其功能强大,而且许多语言都很相似,如果学好C语言,对学习其他语言也有很大帮助 三.编译器的选择 C语言是一门编译型的语言,需要依赖编译器将计算机语言转换成机器能够执行的机器指令 常见的编译器有:msvc...+文件,这里没有C文件选项,因为C++和C基本不分家,将后缀名.cpp改为.c就可以了,创建好后就可以开始写我们的第一个C语言程序了 注意:其中.c的文件叫源文件,.h的文件叫头文件(head),后面会慢慢讲到

    9710

    C语言C语言入门知识

    一、主函数 C语言的主函数是main()函数,有且仅有一个。 例如: int main() { return 0; } 是一个标准的C语言主函数。...二、输入、输出函数 C语言中的输出函数为printf,输入函数为scanf,使用前需要引用头文件#include 。...(2)C语言中的常见单位(从小到大): bit(比特)<byte(字节)<KB<MB<GB<TB<PB<..... 1byte = 8bit 1KB = 1024byte 1MB = 1024KB...四、变量和常量 4.1 变量的使用 C语言中常量是不变的值,变量是可变的值 创建变量的使用: int age = 10; char ch = 'w'; float weight = 45.5f...4.3 常量 C语言中的常量分为字面常量,const修饰的常变量,#define 定义的标识符常量,枚举常量。 (1)字面常量:100,'w',3.14等。

    15710
    领券