密码学:基于python支持448位输入的sha-1算法

2023-12-25 13:58

本文主要是介绍密码学:基于python支持448位输入的sha-1算法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

#只支持448比特

#寄存器的初始值
H0 = 0x67452301
H1 = 0xefcdab89
H2 = 0x98badcfe
H3 = 0x10325476
H4 = 0xc3d2e1f0

#分组的所有字
W=[]

#常数值Kt
def K(t):
    if 0 <= t and t<=19:
        return 0x5a827999
    elif 20 <= t and t<=39:
        return 0x6ed9eba1
    elif 40 <= t and t<=59:
        return 0x8f1bbcdc
    elif 60 <= t and t<=79:
        return 0xca62c1d6
   
#f基本逻辑函数
def F(t,b,c,d):
    if 0 <= t and t<=19:
        return (b&c) | (~b&d)
    elif 20 <= t and t<=39:
        return b^c^d
    elif 40 <= t and t<=59:
        return (b&c) | (b&d) | (c&d)
    elif 60 <= t and t<=79:
        return b^c^d


#比特字Wt的值
def Wt(t):
    a = W[t-16]^W[t-14]^W[t-8]^W[t-3]
    W[t] = S(1,a)
    return W[t]

 


#循环左移k
def S(k,a):
    return ((a>>32-k) | (a<<k) & Sum())


#求32位1
def Sum():
    s = 0;
    for i in range(32):
        s = s + 2**i
    return s

#分割M
def dM(m):
    for i in range(16):
        W[i] = (m>>32*(15-i)) & Sum()
   

 

if __name__ == "__main__":
    A = H0
    B = H1
    C = H2
    D = H3
    E = H4

    i=0
    m = 0
    M = input()
    L = 8*len(M)
    for ch in M:
        m = m*(2**8)+ord(ch)

    if L < 448:
        m = m*2+1
        #添加填充位
        m = m*2**(447 - L)
        #添加长度
        m = m*2**64 + L

    for i in range(80):
        W.append(i)

    dM(m)
    for i in range(16,80):
        Wt(i)


    print(hex(m))

 #80步循环的寄存器
    for t in range(80):
        temp = (S(5,A)%(2**32)+W[t]%(2**32)+E+F(t,B,C,D)+K(t)%(2**32))%2**32
        E = D
        D = C
        C = S(30,B)
        B = A
        A = temp
        print(t,':  ',hex(A),'  ',hex(B),"   ",hex(C),"   ",hex(D),"   ",hex(E))

    A = (A + H0)%2**32
    B = (B + H1)%2**32
    C = (C + H2)%2**32
    D = (D + H3)%2**32
    E = (E + H4)%2**32


    isha = A*2**(4*32) + B*2**(3*32) + C*2**(2*32) + D*2**32 + E
    sha = hex(isha)
    print("消息摘要:",str(sha)[2:])
   
       
       

这篇关于密码学:基于python支持448位输入的sha-1算法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/535752

相关文章

Python从零打造高安全密码管理器

《Python从零打造高安全密码管理器》在数字化时代,每人平均需要管理近百个账号密码,本文将带大家深入剖析一个基于Python的高安全性密码管理器实现方案,感兴趣的小伙伴可以参考一下... 目录一、前言:为什么我们需要专属密码管理器二、系统架构设计2.1 安全加密体系2.2 密码强度策略三、核心功能实现详解

Python Faker库基本用法详解

《PythonFaker库基本用法详解》Faker是一个非常强大的库,适用于生成各种类型的伪随机数据,可以帮助开发者在测试、数据生成、或其他需要随机数据的场景中提高效率,本文给大家介绍PythonF... 目录安装基本用法主要功能示例代码语言和地区生成多条假数据自定义字段小结Faker 是一个 python

Python实现AVIF图片与其他图片格式间的批量转换

《Python实现AVIF图片与其他图片格式间的批量转换》这篇文章主要为大家详细介绍了如何使用Pillow库实现AVIF与其他格式的相互转换,即将AVIF转换为常见的格式,比如JPG或PNG,需要的小... 目录环境配置1.将单个 AVIF 图片转换为 JPG 和 PNG2.批量转换目录下所有 AVIF 图

Python通过模块化开发优化代码的技巧分享

《Python通过模块化开发优化代码的技巧分享》模块化开发就是把代码拆成一个个“零件”,该封装封装,该拆分拆分,下面小编就来和大家简单聊聊python如何用模块化开发进行代码优化吧... 目录什么是模块化开发如何拆分代码改进版:拆分成模块让模块更强大:使用 __init__.py你一定会遇到的问题模www.

详解如何通过Python批量转换图片为PDF

《详解如何通过Python批量转换图片为PDF》:本文主要介绍如何基于Python+Tkinter开发的图片批量转PDF工具,可以支持批量添加图片,拖拽等操作,感兴趣的小伙伴可以参考一下... 目录1. 概述2. 功能亮点2.1 主要功能2.2 界面设计3. 使用指南3.1 运行环境3.2 使用步骤4. 核

Python 安装和配置flask, flask_cors的图文教程

《Python安装和配置flask,flask_cors的图文教程》:本文主要介绍Python安装和配置flask,flask_cors的图文教程,本文通过图文并茂的形式给大家介绍的非常详细,... 目录一.python安装:二,配置环境变量,三:检查Python安装和环境变量,四:安装flask和flas

使用Python自建轻量级的HTTP调试工具

《使用Python自建轻量级的HTTP调试工具》这篇文章主要为大家详细介绍了如何使用Python自建一个轻量级的HTTP调试工具,文中的示例代码讲解详细,感兴趣的小伙伴可以参考一下... 目录一、为什么需要自建工具二、核心功能设计三、技术选型四、分步实现五、进阶优化技巧六、使用示例七、性能对比八、扩展方向建

springboot+dubbo实现时间轮算法

《springboot+dubbo实现时间轮算法》时间轮是一种高效利用线程资源进行批量化调度的算法,本文主要介绍了springboot+dubbo实现时间轮算法,文中通过示例代码介绍的非常详细,对大家... 目录前言一、参数说明二、具体实现1、HashedwheelTimer2、createWheel3、n

基于Python打造一个可视化FTP服务器

《基于Python打造一个可视化FTP服务器》在日常办公和团队协作中,文件共享是一个不可或缺的需求,所以本文将使用Python+Tkinter+pyftpdlib开发一款可视化FTP服务器,有需要的小... 目录1. 概述2. 功能介绍3. 如何使用4. 代码解析5. 运行效果6.相关源码7. 总结与展望1

使用Python实现一键隐藏屏幕并锁定输入

《使用Python实现一键隐藏屏幕并锁定输入》本文主要介绍了使用Python编写一个一键隐藏屏幕并锁定输入的黑科技程序,能够在指定热键触发后立即遮挡屏幕,并禁止一切键盘鼠标输入,这样就再也不用担心自己... 目录1. 概述2. 功能亮点3.代码实现4.使用方法5. 展示效果6. 代码优化与拓展7. 总结1.