zoukankan      html  css  js  c++  java
  • hashlib模块

    加密算法介绍

    HASH

    Hash,一般翻译做“散列”,也有直接音译为”哈希”的,就是把任意长度的输入(又叫做预映射,pre-image),通过散列算法,变换成固定长度的输出,该输出就是散列值。这种转换是一种压缩映射,也就是,散列值的空间通常远小于输入的空间,不同的输入可能会散列成相同的输出,而不可能从散列值来唯一的确定输入值。

    简单的说就是一种将任意长度的消息压缩到某一固定长度的消息摘要的函数。

    HASH主要用于信息安全领域中加密算法,他把一些不同长度的信息转化成杂乱的128位的编码里,叫做HASH值.也可以说,hash就是找到一种数据内容和数据存放地址之间的映射关系

    MD5

    什么是MD5算法

    MD5讯息摘要演算法(英语:MD5 Message-Digest Algorithm),一种被广泛使用的密码杂凑函数,可以产生出一个128位的散列值(hash value),用于确保信息传输完整一致。MD5的前身有MD2、MD3和MD4。

    MD5功能

    输入任意长度的信息,经过处理,输出为128位的信息(数字指纹);
    不同的输入得到的不同的结果(唯一性);

    MD5算法的特点

    1. 压缩性:任意长度的数据,算出的MD5值的长度都是固定的
    2. 容易计算:从原数据计算出MD5值很容易
    3. 抗修改性:对原数据进行任何改动,修改一个字节生成的MD5值区别也会很大
    4. 强抗碰撞:已知原数据和MD5,想找到一个具有相同MD5值的数据(即伪造数据)是非常困难的。

    MD5算法是否可逆?

    MD5不可逆的原因是其是一种散列函数,使用的是hash算法,在计算过程中原文的部分信息是丢失了的。

    MD5用途

    1. 防止被篡改:

      • 比如发送一个电子文档,发送前,我先得到MD5的输出结果a。然后在对方收到电子文档后,对方也得到一个MD5的输出结果b。如果a与b一样就代表中途未被篡改。

      • 比如我提供文件下载,为了防止不法分子在安装程序中添加木马,我可以在网站上公布由安装文件得到的MD5输出结果。

      • SVN在检测文件是否在CheckOut后被修改过,也是用到了MD5.

    2. 防止直接看到明文:

      • 现在很多网站在数据库存储用户的密码的时候都是存储用户密码的MD5值。这样就算不法分子得到数据库的用户密码的MD5值,也无法知道用户的密码。(比如在UNIX系统中用户的密码就是以MD5(或其它类似的算法)经加密后存储在文件系统中。当用户登录的时候,系统把用户输入的密码计算成MD5值,然后再去和保存在文件系统中的MD5值进行比较,进而确定输入的密码是否正确。通过这样的步骤,系统在并不知道用户密码的明码的情况下就可以确定用户登录系统的合法性。这不但可以避免用户的密码被具有系统管理员权限的用户知道,而且还在一定程度上增加了密码被破解的难度。)
    3. 防止抵赖(数字签名):

      • 这需要一个第三方认证机构。例如A写了一个文件,认证机构对此文件用MD5算法产生摘要信息并做好记录。若以后A说这文件不是他写的,权威机构只需对此文件重新产生摘要信息,然后跟记录在册的摘要信息进行比对,相同的话,就证明是A写的了。这就是所谓的“数字签名”。

    SHA-1

    安全哈希算法(Secure Hash Algorithm)主要适用于数字签名标准(Digital Signature Standard DSS)里面定义的数字签名算法(Digital Signature Algorithm DSA)。对于长度小于2^64位的消息,SHA1会产生一个160位的消息摘要。当接收到消息的时候,这个消息摘要可以用来验证数据的完整性。

    SHA是美国国家安全局设计的,由美国国家标准和技术研究院发布的一系列密码散列函数。

    由于MD5和SHA-1于2005年被山东大学的教授王小云破解了,科学家们又推出了SHA224, SHA256, SHA384, SHA512,当然位数越长,破解难度越大,但同时生成加密的消息摘要所耗时间也更长。目前最流行的是加密算法是SHA-256 .

    MD5与SHA-1的比较

    由于MD5与SHA-1均是从MD4发展而来,它们的结构和强度等特性有很多相似之处,SHA-1与MD5的最大区别在于其摘要比MD5摘要长32 比特。对于强行攻击,产生任何一个报文使之摘要等于给定报文摘要的难度:MD5是2128数量级的操作,SHA-1是2160数量级的操作。产生具有相同摘要的两个报文的难度:MD5是264是数量级的操作,SHA-1 是280数量级的操作。因而,SHA-1对强行攻击的强度更大。但由于SHA-1的循环步骤比MD5多80:64且要处理的缓存大160比特:128比特,SHA-1的运行速度比MD5慢。

    Python的hashlib提供了常见的摘要算法,如MD5()、SHA1()、sha3224()、sha3256()、sha3384()、sha3512()、shake128()、shake256()等等。

    #!/urs/bin/evn python
    # -*- coding:utf-8 -*-
    
    
    import hashlib
    hash = hashlib.md5()  # md5对象,md5不能反解,但是加密是固定的,就是关系是一一对应,所以有缺陷,可以被对撞出来
    hash.update(bytes('admin', encoding='utf-8')) # 要对哪个字符串进行加密,就放这里
    print(hash.hexdigest())
    print(hash)
    
    
    
    结果:
    21232f297a57a5a743894a0e4a801fc3
    <md5 HASH object @ 0x00000000021003C8>
    View Code

    如果数据量很大,可以分块多次调用update(),最后计算的结果是一样的:

    import hashlib
    
    sha1 = hashlib.sha1()
    sha1.update(b'how to use sha1 in ')
    sha1.update(b'python hashlib?')
    print(sha1.hexdigest())
    
    
    
    结果: 2c76b57293ce30acef38d98f6046927161b46a44
    View Code

    hash.update(arg)

    用对象arg更新哈希对象,它必须被解释为字节的缓冲区。重复的调用相当于一个调用,其中包含了所有参数的连接:m.update(a);更新(b)相当于m.update(a+b)。

     

    hash.digest()

     返回到目前为止传递给update()方法的数据摘要。这是一个大小为digestsize的字节对象,它可能包含从0到255的整个范围内的字节。
     
    hash.hexdigest()
     
    与文摘()一样,除了摘要作为字符串对象返回,它是双长度的字符串对象,只包含十六进制数字。这可以用于在电子邮件或其他非二进制环境中安全地交换值
     
    hash.copy()
     
    返回哈希对象的副本(“克隆”)。这可以用来有效地计算共享一个共同的初始子字符串的数据摘要。
     
    加盐操作:
    import hashlib
    
    hash3 = hashlib.md5(bytes('abd',encoding='utf-8'))
    ''' 如果没有参数,所以md5遵守一个规则,生成同一个对应关系,如果加了参数,
    就是在原先加密的基础上再加密一层,这样的话参数只有自己知道,防止被撞库,
    因为别人永远拿不到这个参数
    '''
    hash3.update(bytes('admin',encoding='utf-8'))
    print(hash3.hexdigest())
    
    
    
    结果:
    9aea3c0a6c51555c1a4d0a5e9b689ded
    View Code

    其他:

    import hashlib
    
     
    # ######## sha1 ########
     
    hash = hashlib.sha1()
    hash.update('admin')
    print hash.hexdigest()
     
    # ######## sha256 ########
     
    hash = hashlib.sha256()
    hash.update('admin')
    print hash.hexdigest()
     
     
    # ######## sha384 ########
     
    hash = hashlib.sha384()
    hash.update('admin')
    print hash.hexdigest()
     
    # ######## sha512 ########
     
    hash = hashlib.sha512()
    hash.update('admin')
    print hash.hexdigest()
    View Code

    python 还有一个 hmac 模块,它内部对我们创建 key 和 内容 再进行处理然后再加密

    import hmac
    h = hmac.new(b'wueiqi')
    h.update(b'hellowo')
    print(h.hexdigest())
    
    
    
    7faf6763f04441c6b629d23825b81d1b
    View Code

     

    #!/urs/bin/evn python
    # -*- coding:utf-8 -*-
    import hashlib
    
    
    # hashlib简单使用
    def md5(arg):  # 这是加密函数,将传进来的函数加密
        md5_pwd = hashlib.md5(bytes('abd', encoding='utf-8'))
        md5_pwd.update(bytes(arg, encoding='utf-8'))
        return md5_pwd.hexdigest()  # 返回加密的数据
    
    
    def log(user, pwd):  # 登陆时候时候的函数,由于md5不能反解,因此登陆的时候用正解
        with open('db', 'r', encoding='utf-8') as f:
            for line in f:
                u, p = line.strip().split('|')
                if u == user and p == md5(pwd):  # 登陆的时候验证用户名以及加密的密码跟之前保存的是否一样
                    return True
    
    
    def register(user, pwd):  # 注册的时候把用户名和加密的密码写进文件,保存起来
        with open('db', 'a', encoding='utf-8') as f:
            temp = user + '|' + md5(pwd)
            f.write(temp)
    
    
    i = input('1表示登陆,2表示注册:')
    if i == '2':
        user = input('用户名:')
        pwd = input('密码:')
        register(user, pwd)
    elif i == '1':
        user = user = input('用户名:')
        pwd = input('密码:')
        r = log(user, pwd)  # 验证用户名和密码
        if r == True:
            print('登陆成功')
        else:
            print('登陆失败')
    else:
        print('账号不存在')
    View Code

     

    详细:https://docs.python.org/3/library/hmac.html

    详细:https://docs.python.org/3/library/hashlib.html

     

     

  • 相关阅读:
    计蒜客 跳跃游戏2
    计蒜客 跳跃游戏
    2018 计蒜之道-初赛 第一场 A-百度无人车
    poj 3625 (最小生成树算法)
    poj 3623(贪心)
    poj2386(dfs搜索水题)
    poj 2761 主席树的应用(查询区间第k小值)
    POJ 2456 编程技巧之------二分查找思想的巧妙应用
    POJ 1995(有关快速幂运算的一道水题)
    1441:【例题2】生日蛋糕
  • 原文地址:https://www.cnblogs.com/zqxqx/p/8810790.html
Copyright © 2011-2022 走看看