• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    python实现希尔密码加密的示例代码

    原理

    希尔密码是运用基本矩阵论原理的替换密码,由Lester S. Hill在1929年发明。

    每个字母当作26进制数字:A=0, B=1, C=2… 一串字母当成n维向量,跟一个n×n的矩阵相乘,再将得出的结果模26。(注意用作加密的矩阵(即密匙)在 必须是可逆的,否则就不可能解码。只有矩阵的行列式和26互质,才是可逆的。)

    实现

    希尔密码是运用基本矩阵论原理的替换密码,使用一个m*m的矩阵作为密钥,此矩阵必须可逆,解密使用逆矩阵解密。

    使用numpy库的矩阵对象,可以十分方便地进行矩阵乘法,矩阵求逆和取模等运算。

    import numpy as np
    
    m = 'YOURPINNOISFOURONETWOSIX'  #明文
    a = np.matrix([[11,2,19],[5,23,25],[20,7,17]])  #密钥LCTFXZUHR
    num_m = []
    temp = []
    count = 1
    for i in m:  #将明文分为三个一组
        temp.append(ord(i)-ord('A'))
        if count % 3 == 0:
            num_m.append(temp)
            temp = []
        count += 1
    mat_m = [np.matrix(i).T for i in num_m]  #将明文分组转换为向量形式
    mat_c = [a * i % 26 for i in mat_m]  #得到密文分组的向量形式
    num_c = []
    temp = []
    for i in mat_c:  #将密文向量转换为列表形式,且合并到一个列表
        temp = i.tolist()
        for j in range(3):
            num_c.append(temp[j][0])
    c = [chr(i+ord('A')) for i in num_c]
    print(''.join(c))  #连接成字符串,输出密文
    
    

    到此这篇关于python实现希尔密码加密的示例代码的文章就介绍到这了,更多相关python 希尔密码加密内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

    您可能感兴趣的文章:
    • 使用python实现希尔、计数、基数基础排序的代码
    • Python排序搜索基本算法之希尔排序实例分析
    • Python实现希尔排序算法的原理与用法实例分析
    • python编程实现希尔排序
    • python实现的希尔排序算法实例
    上一篇:OpenCV计算平均值cv::mean实例代码
    下一篇:浅谈Tensorflow2对GPU内存的分配策略
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    python实现希尔密码加密的示例代码 python,实现,希尔,密码,加密,