密码学中的sponge函数

1. Hash函数特性

Hash函数是将任意长度的输入,映射为固定长度的输出:
h : Z 2 ∗ ↦ Z 2 n h:Z_2^*\mapsto Z_2^n h:Z2Z2n
通常 n n n的取值为:128,160,256,512。
在这里插入图片描述
在这里插入图片描述
Hash函数应具有如下特性:

  • Pre-image resistant:即已知 y y y,根据 h ( x ) = y h(x)=y h(x)=y x x x,需要 2 n 2^n 2n次尝试。
    在这里插入图片描述
  • 2nd pre-image resistance:已知 M M M h ( M ) h(M) h(M),找到另一个 M ′ M' M使得 h ( M ′ ) = h ( M ) h(M')=h(M) h(M)=h(M),需要 2 n 2^n 2n次尝试。
    在这里插入图片描述
  • Collision resistance:找到任意的 x 1 ! = x 2 x_1!=x_2 x1!=x2,使得 h ( x 1 ) = h ( x 2 ) h(x_1)=h(x_2) h(x1)=h(x2),需要 2 n / 2 2^{n/2} 2n/2次尝试。
    在这里插入图片描述

一个好的Hash函数,应表现得像一个random oracle。

密码学中Hash函数可用于:

  • 签名:用 s i g n R S A ( h ( M ) ) sign_{RSA}(h(M)) signRSA(h(M))代替 s i g n R S A ( M ) sign_{RSA}(M) signRSA(M)
  • 密钥推导:由主key K K K推导keys K i = h ( K ∣ ∣ i ) K_i=h(K||i) Ki=h(Ki)
  • Bit commitment, predictions: h ( w h a t   I   k n o w ) h(what\ I\ know) h(what I know)
  • 消息认证: h ( K ∣ ∣ M ) h(K||M) h(KM)

2. random oracle

random oracle(RO)是将任意长度的消息映射为无限输出string。
支持的输入参数为 ( M , l ) (M,l) (M,l),其中 M M M代表的是输入的消息, l l l代表希望的输出字符串的长度。
输出为 Z Z Z,为 l l l长度的字符串。是独立且均匀分布的字符。
random oracle的输出是自洽的,即相同的输入,对应相同的输出。

random oracle没有internal collisions。

3. tranditional construction——Merkle-Damgård

在这里插入图片描述
在这里插入图片描述

4. sponge construction

在这里插入图片描述
f f f被称为 b b b-bit排列函数(同时也为extendable output function(XOF)), b = r + c b=r+c b=r+c,其中的 r r r为bits of rate, c c c为bits of capacity(security parameter)。

4.1 sponge函数

sponge函数又可称为海绵函数,主要分为两个阶段:

  • absorbing 吸收阶段。对应该阶段的为hash碰撞。
  • squeezing 挤压阶段。对应该阶段的为周期性output。

论文 《Sponge functions》中sponge函数等的定义如下:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

5. duplex construction

在这里插入图片描述

参考资料:
[1] Sponge functions
[2] Introduction to sponge-based cryptography Part 1: Keccak and SHA-3
[3] Cryptographic sponge functions
[4] 博客Fiat-Shamir heuristic(含实现)和Random oracle

  • 1
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
使用Sponge结构的密码杂凑函数是一种常见的密码学原语,它可以用于构建安全的密码杂凑算法。下面是对使用Sponge结构的密码杂凑函数的详细描述: 1. Sponge结构概述: - Sponge结构是一种基于置换和固定输入长度的可逆函数结构。它由两个主要部分组成:置换函数(Permutation)和吸收函数(Absorption)。 - 置换函数是一个可逆的变换函数,将输入数据进行置换和混淆,以增加密码杂凑算法的安全性。 - 吸收函数接受输入数据,并将其分成固定长度的块,然后通过与置换函数的迭代运算来混合和处理这些块。 2. Sponge结构的工作方式: - 吸收阶段:输入数据被分成固定长度的块,然后通过与置换函数的迭代运算进行混合和处理。每个块都会与当前状态进行异或运算,然后通过置换函数更新状态。 - 挤压阶段:在吸收阶段完成后,继续进行一些迭代运算,以生成输出数据。输出数据的长度可以根据需要进行调整。 - 迭代次数:Sponge结构的安全性和性能取决于迭代次数。较高的迭代次数可以提供更高的安全性,但也会增加计算成本。 3. 安全性和应用: - 使用Sponge结构的密码杂凑函数,如Keccak和SHA-3,被广泛应用于密码学领域,如数字签名、消息认证码、密钥派生等。 - Sponge结构具有较好的安全性特性,如抗碰撞、抗第二前像和抗预像等性质。 - 由于其灵活性和可扩展性,Sponge结构还可以用于构建其他密码学原语,如伪随机数生成器(PRNG)和可扩展认证(eXtensible Authentication Protocol,EAP)等。 总体而言,使用Sponge结构的密码杂凑函数是一种有效且安全的密码学原语,它通过吸收和挤压阶段的迭代运算来处理输入数据,并提供了多种应用所需的安全性特性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值