python hashlib加密实现代码

  

用于加密相关的操作,代替了md5模块和沙模块,主要提供SHA1, SHA224, SHA256, SHA512, md5算法。

  

以下是算法示例:

        # !/usr/bin/env python   # - * -编码:utf - 8 - *   进口hashlib   #=================MD5()加密=====================hhb=hashlib。md5(字节(“jahiuhfdakj”,编码=皍tf - 8”)) #加盐处理   ret=hhb。更新(字节(“123”,编码=皍tf - 8”)) #“123”是需要加密的字符串   打印(“MD5加密:“,hhb.hexdigest ())         #=================SHA1()加密=====================hhb=hashlib.sha1 ()   ret=hhb。更新(字节(“123”,编码=皍tf - 8”))   打印(SHA1加密:“,hhb.hexdigest ())         #=================SHA224()加密=====================hhb=hashlib.sha224 ()   ret=hhb。更新(字节(“123”,编码=皍tf - 8”))   打印(“SHA224加密:“,hhb.hexdigest ())      #=================SHA256()加密=====================hhb=hashlib.sha256 ()   ret=hhb。更新(字节(“123”,编码=皍tf - 8”))   打印(“SHA256加密:“,hhb.hexdigest ())      #=================SHA512()加密=====================hhb=hashlib.sha512 ()   ret=hhb。更新(字节(“123”,编码=皍tf - 8”))   打印(“SHA512加密:“,hhb.hexdigest ())      #=================SHA3_256()加密=====================hhb=hashlib.sha3_256 ()   ret=hhb。更新(字节(“123”,编码=皍tf - 8”))   打印(“SHA3_256加密:“,hhb.hexdigest ())      #=================SHA3_384()加密=====================hhb=hashlib.sha3_384 ()   ret=hhb。更新(字节(“123”,编码=皍tf - 8”))   打印(“SHA3_384加密:“,hhb.hexdigest ())      #=================SHA3_512()加密=====================hhb=hashlib.sha3_512 ()   ret=hhb。更新(字节(“123”,编码=皍tf - 8”))   打印(“SHA3_512加密:“,hhb.hexdigest ())      

算法示例的结果:

        MD5加密:113 ccbcda570622489c183f6a6e0121e   SHA1加密:40 bd001563085fc35165329ea1ff5c5ecbdbbeef   SHA224加密:78 d8045d684abd2eece923758f3cd781489df3a48e1278982466017f   SHA256加密:a665a45920422f9d417e4867efdc4fb8a04a1f3fff1fa07e998e86f7f7a27ae3   c9909afec25354d551dae21590bb26e38d53f2173b8d3dc3eee4c047e7ab1c1eb8b85103e3be7ba613b31bb5c9c36214dc9f14a42fd7a2fdb84856bca5c44c2 SHA512加密:3   SHA3_256加密:a03ab19b866fc585b5cb1812a2f63ca861e7e7643ee5d43fd7106b623725fd67   bd942d1678a25d029b114306f5e1dae49fe8abeeacd03cfab0f156aa2e363c988b1c12803d4a8c9ba38fdc873e5f007 SHA3_384加密:9   SHA3_512加密:48 c8947f69c054a5caa934674ce8881d02bb18fb59d5a63eeaddff735b0e9801e87294783281ae49fc8287a0fd86779b27d7972d3e84f0fa0d826d7cb67dfefc      

基于hashlib.md5()对密码进行加密实现用户登录验证的示例:

        # !/usr/bin/env python   # - * -编码:utf - 8 - *      进口hashlib   #基于MD5对密码进行加密实现用户登录验证      def md5 (arg):   ”“”   使用hashlib.md5()对密码进行加密处理   :参数arg:需要加密处理的密码   返回:   ”“”   散列=hashlib。md5(字节(“我在学习python”,编码=皍tf - 8”)) #加盐,使用密码加密更有保障   散列。更新(字节(参数、编码=皍tf - 8”))   返回hash.hexdigest ()      def登录(用户名、密码):   ”“”   用于用户登录验证   :param用户名:用户名   :param密码:密码   返回:真的,登录成功,假的,登录失败。   ”“”   张开(“用户。txt”、“r”,编码=皍tf - 8”) f:   f的线:   行=line.strip() #默认地带无参数,会去掉首尾空格,换行符;有参数则去除指定值   line_list=line.split(“|”) #以|符号提取用户名和密码   如果用户名==line_list[0]和md5(密码)==line_list [1]:   还真   其他:   返回假      def注册(用户名、密码):   ”“”   用户注册   :param用户名:用户名   :param密码:密码   返回:真的,注册成功   ”“”   张开(“用户。txt”、“”,编码=" utf - 8 ") f:   temp=" \ n " +用户名+“|”+ md5(密码)#“\ n”换行符   f.write(临时)   还真      def user_exsit(用户名):   ”“”   注册时,判断用户名是否存在   :param用户名:用户名   返回:真的,用户名已存在   ”“”   张开(“用户。txt”、“r”,编码=皍tf - 8”) f:   f的线:   行=line.strip ()   line_list=line.split (“|”)   如果用户名==line_list [0]:   还真   返回假      def main ():   打印(“欢迎您使用本系统,请输入你进行操作选项”。)   输入=输入(" 1。登录;2。注册。请输入编号:”)   如果输入==?”:   *=1   而真正的:   如果*==4:   打印(“输入3次用户名或密码不正确,请在一小时后再重试。”)   打破   用户=输入(“请输入你的用户名:”)   pwd=输入(“请输入你的密码:")   is_login=登录(用户、pwd)   如果is_login:   打印(“恭喜您!系统登录成功”。)   打破   其他:   打印(“用户名或密码不正确。”)   * +=1   如果输入==?”:   用户=输入(“请输入你的用户名:”)   pwd=输入(“请输入你的密码:")   如果user_exsit(用户):   打印(“用户名已经存在,注册失败!”)   其他:   ret=注册(用户、pwd)   如果延迟:   打印(“注册成功!”)   其他:   打印(“注册失败!”)      main ()

python hashlib加密实现代码