基于ARX结构的新型序列密码算法FlashLight
2026/6/8 1:33:18 网站建设 项目流程

基于ARX结构的新型序列密码算法FlashLight

FlashLight算法简介

FlashLight算法属于对称加密算法5大分支之一的序列密码算法。它是在Salsa20的基础上进行改变的,相较于Salsa20来说,其每轮的混淆性和扩散性更好,可以更有效地抵抗现有的和未知的密码分析。其核心是一种800比特输入,800比特输出的ARX结构部件,密钥长度分为128比特和256-bit两种规格。

FlashLight算法参数

FlashLight算法主要以Word(32位)为单位来进行处理,每个Word定义为32-bit二进制数。FlashLight算法的核心函数是将一个128-bit(将128比特密钥扩展为256比特) 或者256-bit的密钥(k1,……,k7),一个128-bit的时间标号(t0,t1,t2,t3),一个128-bit的初始IV(v0,v1,v2,v3)和9个32-bit的常数(c0,c1,…,c7,c8)转换为一个800-bit的输出。其输入可以用两个5×5矩阵的映射关系来表示,如下图所示:

FlashLight算法初始化

其中9个32位常数(c0,c1,…,c7,c8)如下图所示:

FlashLight算法状态更新

流密码FlashLight的轮函数是RoundFunction,总共进行20轮。经过20轮(“FlashLight”中的20即指轮数)后,得到最终的密钥流。

其中RoundFunction伪代码如下所示:

X=RoundFunction(X)

{

X[5][5]=X[25]

Part1.行变换

FFFFF0(X[0][*])

FFFFF1(X[1][*])

FFFFF2(X[2][*])

FFFFF3(X[3][*])

FFFFF4(X[4][*])

Part2.左对角线变换

X[2][2]=X[2][2]⊕(X[0][0]<<<6)⊕(X[1][1]<<<11)⊕(X[3][3]<<<15)⊕(X[4][4]<<<26)

Part3.列变换

FFFFF0(X[*][0])

FFFFF1(X[*][1])

FFFFF2(X[*][2])

FFFFF3(X[*][3])

FFFFF4(X[*][4]) \\

Part4.右对角线变换

X[2][2]=X[2][2]⊕(X[0][4]<<<13)⊕(X[1][3]<<<18)⊕(X[3][1]<<<10)⊕(X[4][0]<<<21)

}

其中输入和输出均为5个32位字的5个混淆扩散函数(相当于160比特大S盒)FFFFF0,FFFFF1,FFFFF2,FFFFF3,FFFFF4分别如下图所示:

FlashLight算法密钥流生成

记执行20轮的轮变换操作后的状态为S20=(x020,……,x2420),则输出密钥流为:FlashLight(S0)=S0+S20。设明文为M密文为C,加密过程可表示为:C=M⊕FlashLight(S),

解密过程为M=C⊕FlashLight(S)。

FlashLight算法总结

FlashLight和Salsa20很类似,主要有三点不同:内部状态矩阵的初始化,轮函数及向量进入轮函数的方式。感兴趣的同学可以参考基于ARX结构的流密码算法Salsa20FlashLight是一个脱胎于Salsa20的新型序列密码算法,它凭借卓越的软件性能、强抗时序攻击能力和简洁设计,在与AES的竞争中赢得了重要地位。FlashLight仅使用ARX操作,无需复杂的S盒查表,使其算法描述简洁,代码实现紧凑,易于在多种平台上部署。它与Poly1305的组合已成为保护互联网通信的基石之一。

需要专业的网站建设服务?

联系我们获取免费的网站建设咨询和方案报价,让我们帮助您实现业务目标

立即咨询