利用Python如何生成hash值示例详解
一、介绍 如果在Python中需要对用户输入的密码或者其他内容进行加密,首选的方法是生成hash值。 在Python中可以利用二个模块来进行: - crypt - hashlib 二、crypt (一)crypt的主要方法和常量
(二)使用说明与示例 使用crypt.crypt(…)进行hash加密的时候,需要提供二个参数: - 加密内容 - salt 如果不特别指定salt,系统就会调用crypt.mksalt(…)生成一个salt 如果想要以特定的加密算法生成salt就应该使用下面的命令: >>>salt = crypt.mksalt(crypt.METHOD_SHA512) >>> salt '$6$s8Q3eNP6urKZb3AK' 然后再进行数据加密: >>> hash = crypt.crypt("helloworld",salt) >>> hash '$6$s8Q3eNP6urKZb3AK$L0O5cqHRU.1f170bV2KrjF3LkLL54So442TqUIsk.wYtCtOSD4Tyt./fj6W6Y.EzrbNm00grA4yPPhXGya2ie1' 三、hashlib (一)hashlib的主要方法和常量
**(二)Hash对象特有的方法 如果你利用 hashlib 生成了一个Hash对象,那么这个Hash对象会包含如下方法:
(三)示例 1、直接使用hashlib方法 >>> hashlib.sha224("Nobody inspects the spammish repetition") <sha224 HASH object @ 0x7f99432c5b28> >>> hashlib.sha224("Nobody inspects the spammish repetition").hexdigest() 'a4337bc45a8fc544c03f52dc550cd6e1e87021bc896588bd79e901e2' 2、直接使用Hash对象中的方法 >>> m = hashlib.md5() >>> m <md5 HASH object @ 0x7f99432c5468> >>> m.update("Nobody inspects") >>> m.digest() '>xf7)xccxf0xccVx07x9cxa5Fxd5x80x83xdcx12' >>> m.update(" the spammish repetition") >>> m.digest() 'xbbdx9cx83xddx1exa5xc9xd9xdexc9xa1x8dxf0xffxe9' >>> m.hexdigest() 'bb649c83dd1ea5c9d9dec9a18df0ffe9' 我是如何 Python 一句话校验软件哈希值的 MD5 python -c "import hashlib,sys;print hashlib.md5(open(sys.argv[1],'rb').read()).hexdigest()" Shadowsocks.exe 校验 下载软件是否被“中间人动过手脚” 例如:校验shadowsocks SHA-1 python -c "import hashlib,sys;print hashlib.sha1(open(sys.argv[1],'rb').read()).hexdigest()" Shadowsocks.exe SHA-256 python -c "import hashlib,sys;print hashlib.sha256(open(sys.argv[1],'rb').read()).hexdigest()" Shadowsocks.exe SHA-512 python -c "import hashlib,sys;print hashlib.sha512(open(sys.argv[1],'rb').read()).hexdigest()" Shadowsocks.exe 总结 以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对编程小技巧的支持。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |