hashlib模块与hmac模块

一些想法

今天学到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()#和另外一个密文对比,验证一致性

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

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 218,036评论 6 506
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,046评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,411评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,622评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,661评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,521评论 1 304
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,288评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,200评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,644评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,837评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,953评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,673评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,281评论 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,889评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,011评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,119评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,901评论 2 355

推荐阅读更多精彩内容