美文网首页
hashlib模块与hmac模块

hashlib模块与hmac模块

作者: 漓江塔塔主 | 来源:发表于2018-07-24 09:50 被阅读0次

    一些想法

    今天学到tcp协议的验证客户端的合法性方法,既然建立了服务器端,假如不想让任意一个客户端都能轻易的连接,那么就必然要做验证,就涉及到了两者验证一致性的内容,而今天学的hmac模块就解决了这个问题,而hmac模块又与hashlib模块有着非常相似的使用方法,所以干脆就顺便复习了。

    hashlib模块

    要想了解hashlib模块,首先应该了解摘要算法

    什么是摘要算法呢?摘要算法又称哈希算法、散列算法。它通过一个函数,把任意长度的数据转换为一个长度固定的数据串(通常用16进制的字符串表示)。

    而hashlib模块就提供了摘要算法。而常用的算法又包括md5,sha1。但是摘要算法又有一个很明显的特性,只能加密不能解密,所以并不能用来对数据进行加密操作。但是它对于同一个数据进行计算,结果总是相同的,所以hashlib就常常应用在验证一致性的场景。比如一个用户登陆系统,需要保存用户名与密码,而一旦对密码进行hashlib模块的加密,即使是数据泄露,密文也不会被破译,而得到的字符串只在用户登陆时应用,只要密码加密后的密文与数据库内相同,自然就验证完成。
    而hashlib模块应用起来也很方便,以md5为例:

    import hashlib
    db = {
        'michael': 'e10adc3949ba59abbe56e057f20f883e',
        'bob': '878ef96e86145580c38c87f0410ad153',
        'alice': '99b1c2188db85afee403b1536010c2c9'
    }
    def login(user, password):
        md=hashlib.md5()
        if user in db:
            md.update(password.encode('utf-8'))
            info=md.hexdigest()
            if info == db[user]:
                print('登陆成功')
            else:
                print('密码错误')
        else:
            print('用户名不存在')
    login('michael', '123456')
    login('bob', 'abc999')
    login('alice', 'alice2008')
    

    当然上面只是一个简单的加密算法,生活中我们见到的密码不可能是以这种简单的方法加密,因为这种加密算法有一个明显的缺点,就是容易撞库。虽然加密是一个单向的过程,并不会被破解,但是一旦别人拿大量的数据进行加密操作,拿到得到的密文和你的密文对比,只要一样,你的密码也就暴露了。
    所以在hashlib模块中还有一种加盐的操作,来让自己的数据更加安全。

    md5=hashlib. md5(salt.encode('utf-8'))
    

    在这个基础之上又有动态加盐等等操作,力求更加安全。

    hmac模块

    hamc模块可以说是在我们的加盐算法基础之上python带的一种加密算法。应用这个算法,首先要提供一段secret_key

    import hmac#模块和hashlib一样
    secret_key=b'hmac'
    h=hmac.new(key, message, digestmod='MD5')#secret_key,加密内容,你想进行加密的二进制类型
    h.digest()#得到密文
    hmac.compare_digest()#和另外一个密文对比,验证一致性
    

    这样产生的密文也更加安全。

    相关文章

      网友评论

          本文标题:hashlib模块与hmac模块

          本文链接:https://www.haomeiwen.com/subject/sgyjmftx.html