• 分组密码


    基本原理:代换,扩散,混淆。

    结构:

      1.Feistel网络:将明文一份为2,明文x = L0R0。

        对于1<=i<=r有:

            Li = R(i-1)

            Ri=Li-1异或F(Ri-1,Ki)

          

        优点:加密与解密相似

           Feistel型分组密码的加密过程的最后一轮没有进行左右交换,目的就是为了可以利用同一算法实现加解密。

      2.非平衡的Feistel网络

        明文x = 2mbit

        也是将明文分成L0R0两部分,但是L0≠R0,L0=n1bit R0=n2bit n1+n2=2m

        对于1<=i<=r有:

            

      3.SP网络:

        加密思想:x是明文,长度为nbit,令X0=x,对于1<=i<=r,在子密钥Ki的控制下,对Xi-1做代换S,然后再做置换或可逆的线性变换p,密文为y=X,r是圈变换的迭代次数。

         

       SP网络可以看做Feistel网络的推广,但是SP的加密和解密过程不同。

    分组密码算法的设计要求如下。 (1)分组长度n要足够大,防止明文穷举攻击奏效。 (2)密钥量要足够大,尽可能消除弱密钥并使所有密钥同等好,但密钥不能过长,以便管理。 (3)由密钥确定置换的算法要足够复杂,充分实现明文与密钥的扩散和混淆。 (4)加密和解密运算简单,易于软件和硬件高速实现。 (5)数据扩展。 (6)差错传播尽可能小。

  • 相关阅读:
    通过构造函数检查生成对象个数
    动手动脑二
    产生随机数的几种方法
    素数输出
    递归实现回文串
    java的方法重载
    统计单词频率
    四则运算和随机验证码
    微信小程序--家庭记账本开发--04
    微信小程序--家庭记账本开发--03
  • 原文地址:https://www.cnblogs.com/beautiful7/p/12793223.html
Copyright © 2020-2023  润新知