数据认证算法(DAA)  Data Authentication Algorithm

  DAA建立在DES之上,该算法比较陈旧,人们已经发现了这个算法的安全弱点,目前已经被废止。

  DAA和CMAC-LMLPHP

  DAA采用DES运算的CBC工作模式,其初始向量为0,需要认证的数据分成连续的64位分组D,D,...,D,若最后分组不足64位,则在其后填充0补足。

  DAA的安全隐患

    给定一个消息分组X的CBC MAC码,如T = MAC(K , X),则攻击者马上就知道对于两个消息分组 X || (T⊕X) 的CBC MAC码还是T。显然,对于短消息,攻击者可以很容易就找到符合条件的M'使得MAC(K , M') = MAC(K , M)。

基于密码的消息认证吗(CMAC)  Cipher-based Message Authentication Code

  CMAC的加密对于AES和3DES都适用。

  DAA和CMAC-LMLPHP

  为消除DAA存在的安全隐患,CMAC在DAA基础上做了一个改进,在最后一步加密的前后均作了数学处理

     C = E(K , [M⊕C⊕K])

     T = MSB(C)

          Tlen是T的长度,MSB(X)是取位串X最左边的s位

  两位n位的密钥K和K由K按照如下方式导出:

    L = E(K , 0)      //将分组密码应用到一个全0分组上

    K = L • x        

    K = L • x = (L • x) • x

    乘法(•)在域GF(2)内进行,x和x是域GF(2)的一次和二次多项式

  

04-29 23:54