【密码学——基础理论与应用】李子臣编著 第四章 SM4分组密码算法 课后习题

免责声明

这里都是自己搓或者手写的。

里面不少题目感觉有问题或者我的理解有偏颇,请大佬批评指正!

不带思考抄作业的请自动退出,我的并非全对,仅仅提供思维!

SM4的python实现

基于AI生成的SM4加密算法-CSDN博客

题目

逐题解析

4.1

B 这个不用解析吧,,,

4.2

B4 也不用解释吧,,,

4.3

答案:SM4的加密轮函数,加密变换:

将SM4的加密轮函数,分成加密函数G和数据交换E;

轮函数

这说明加密函数G是对合的。

因为,E变换为

显然,E是对合运算。综上,轮函数是对合的。

SM4的加密过程为:

SM4的解密过程为:

比较 可知,运算相同,只有密钥的使用顺序不同。所以SM4是对合的。

4.4

答案:SM4的加密过程的数据变化:

(其中最后一步变换为反序)

密文(Y0,Y1,Y2,Y3)解密过程数据的变化:

(其中最后一步变换为反序)

所以SM4是可逆的。

4.5

python 复制代码
# 设置一个128位的密钥
keystr = "Love you perfect"
key = 0x0123456789abcdeffedcba9876543210  # 32*4
# S盒
s = [[214, 144, 233, 254, 204, 225, 61, 183, 22, 182, 20, 194, 40, 251, 44, 5],
    [43, 103, 154, 118, 42, 190, 4, 195, 170, 68, 19, 38, 73, 134, 6, 153],
    [156, 66, 80, 244, 145, 239, 152, 122, 51, 84, 11, 67, 237, 207, 172, 98],
    [228, 179, 28, 169, 201, 8, 232, 149, 128, 223, 148, 250, 117, 143, 63, 166],
    [71, 7, 167, 252, 243, 115, 23, 186, 131, 89, 60, 25, 230, 133, 79, 168],
    [104, 107, 129, 178, 113, 100, 218, 139, 248, 235, 15, 75, 112, 86, 157, 53],
    [30, 36, 14, 94, 99, 88, 209, 162, 37, 34, 124, 59, 1, 33, 120, 135],
    [212, 0, 70, 87, 159, 211, 39, 82, 76, 54, 2, 231, 160, 196, 200, 158],
    [234, 191, 138, 210, 64, 199, 56, 181, 163, 247, 242, 206, 249, 97, 21, 161],
    [224, 174, 93, 164, 155, 52, 26, 85, 173, 147, 50, 48, 245, 140, 177, 227],
    [29, 246, 226, 46, 130, 102, 202, 96, 192, 41, 35, 171, 13, 83, 78, 111],
    [213, 219, 55, 69, 222, 253, 142, 47, 3, 255, 106, 114, 109, 108, 91, 81],
    [141, 27, 175, 146, 187, 221, 188, 127, 17, 217, 92, 65, 31, 16, 90, 216],
    [10, 193, 49, 136, 165, 205, 123, 189, 45, 116, 208, 18, 184, 229, 180, 176],
    [137, 105, 151, 74, 12, 150, 119, 126, 101, 185, 241, 9, 197, 110, 198, 132],
    [24, 240, 125, 236, 58, 220, 77, 32, 121, 238, 95, 62, 215, 203, 57, 72]]

def string_to_128bit_hex_number(input_string):
    # 将字符串中的每个字符转换为 ASCII 码值,再转换为两位的十六进制数
    hex_string = ''.join(f"{ord(char):02x}" for char in input_string)

    # 将十六进制字符串转换为整数
    hex_number = int(hex_string, 16)
    print("密钥key的十六进制表示: "+hex_string)

    return hex_number

def Sbox(input_int):
    # 将输入的十六进制数转换为整数
    row = input_int // 16
    col = input_int % 16

    output_int = s[row][col]
    return output_int

def T(a, b, c, d, shifts):
    """通用的T函数,用于T1和T2"""
    temp = a ^ b ^ c ^ d
    parts = [(temp >> (24 - 8 * i)) & 0xFF for i in range(4)]

    res = [Sbox(part) for part in parts]
    # print(parts,res) # 非常重要的检验中间过程的语句,S的机算可能是错的
    B = (res[0] << 24) | (res[1] << 16) | (res[2] << 8) | res[3]
    result = B
    for shift in shifts:
        result ^= ((B << shift) | (B >> (32 - shift))) & 0xFFFFFFFF # 确保结果是32位
    return result

def T2(K1, K2, K3, CK):
    """T2函数"""
    return T(K1, K2, K3, CK, [13, 23])

def jiamimiyao():
    # 如果需要将整数转换为二进制字符串
    binary_key = bin(key)[2:].zfill(128)  # 确保长度为128位
    print(f"key 的二进制表示: {binary_key}")

    # 定义掩码(32位掩码)
    mask = (1 << 32) - 1

    MK0 = (key >> 96) & mask  # 前32位
    MK1 = (key >> 64) & mask  # 第33到64位
    MK2 = (key >> 32) & mask  # 第65到96位
    MK3 = key & mask          # 第97到128位

    return MK0, MK1, MK2, MK3

def lunmiyao(MK0, MK1, MK2, MK3):
    FK0 = 0xa3b1bac6
    FK1 = 0x56aa3350
    FK2 = 0x677d9197
    FK3 = 0xb27022dc

    ck = [[0 for _ in range(32)] for _ in range(4)]
    CK = [0]*32
    for i in range(32):  # 遍历每一列
        for j in range(4):  # 遍历每一行
            ck[j][i] = (4*i+j)*7 % 256  # 注意这里填充的是 ck[j][i]
        # 将 CK[i] 转换为整数
        CK[i] = (ck[0][i] << 24) | (ck[1][i] << 16) | (ck[2][i] << 8) | ck[3][i]

    K = [0] * 36
    # 计算异或结果
    K[0] = MK0 ^ FK0
    K[1] = MK1 ^ FK1
    K[2] = MK2 ^ FK2
    K[3] = MK3 ^ FK3

    for i in range(32):
        K[i+4] = K[i] ^ T2(K[i+1], K[i+2], K[i+3], CK[i])
        print(f"rk[{i}] = {hex(K[i+4])}")

    return K

if __name__ == "__main__":
    string_to_128bit_hex_number(keystr)
    MK0, MK1, MK2, MK3 = jiamimiyao()
    K = lunmiyao(MK0, MK1, MK2, MK3)

4.6

python 复制代码
input_num = 0xAE260F63

def T(input_num, shifts):
    """通用的T函数,用于T1和T2"""
    B = input_num
    result = B
    for shift in shifts:
        result ^= ((B << shift) | (B >> (32 - shift))) & 0xFFFFFFFF # 确保结果是32位
    return result

def T1(K):
    """T1函数"""
    return T(K, [2, 10, 18, 24])

if __name__ == "__main__":
    result = T1(input_num)
    print("线性变换的输出是: "+hex(result))
相关推荐
墨绿色的摆渡人1 小时前
pytorch小记(十):pytorch中torch.tril 和 torch.triu 详解
人工智能·pytorch·python
神秘的土鸡1 小时前
Centos搭建Tomcat服务器:我的实战经验分享(成功版本 详细!)
linux·开发语言·python·tomcat·web
程序员JerrySUN1 小时前
TensorFlow:从历史到应用
人工智能·python·tensorflow
太虚2 小时前
备赛蓝桥杯-Python-Day1-基础语法回顾
python·蓝桥杯
衫水2 小时前
1.FastAPI简介与安装
开发语言·python·fastapi
ningmengjing_2 小时前
django小案例-2
后端·python·django
蹦蹦跳跳真可爱5892 小时前
Python----计算机视觉处理(Opencv:ROI图像切割)
人工智能·python·opencv·计算机视觉
小小鱼er2 小时前
python flask项目架构搭建
python·flask
小白学大数据2 小时前
Superagent 异步请求:如何处理复杂的 HTTP 场景
开发语言·网络·python·网络协议·http
SomeB1oody2 小时前
【Python机器学习】3.2. 决策树理论(进阶):ID3算法、信息熵原理、信息增益
python·算法·决策树·机器学习