1. <strong id="7actg"></strong>
    2. <table id="7actg"></table>

    3. <address id="7actg"></address>
      <address id="7actg"></address>
      1. <object id="7actg"><tt id="7actg"></tt></object>

        盤點 Python 加密解密模塊 hashlib 常見的 7 種加密算法

        共 2510字,需瀏覽 6分鐘

         ·

        2021-04-29 14:37



        大家好,我是安果!

        今天給大家介紹 hashlib 模塊常見的集中機密算法!

        前言

        在程序中我們經(jīng)??梢钥吹接泻芏嗟募用芩惴?,比如說 MD5 sha1 等

        今天我們就來了解下這下加密算法的吧,在了解之前我們需要知道一個模塊嘛就是hashlib,他就是目前 Python 提供字符加密的模塊,它加密的字符類型為二進制編碼,所以直接加密字符串會報錯

        import hashlibstring='任性的90后boy'#使用encode進行轉(zhuǎn)換sha1 = hashlib.sha1()sha1.update(string.encode('utf-8'))res = sha1.hexdigest()print("sha1采用encode轉(zhuǎn)換加密結(jié)果:",res)#使用byte轉(zhuǎn)換為二進制sha1 = hashlib.sha1()sha1.update(bytes(string,encoding='utf-8'))res = sha1.hexdigest()print("sha1采用byte轉(zhuǎn)換的結(jié)果:",res)

        可以使用下列這兩種方法任意一種獲取到 hashlib 中所有的散列算法集合:

        import hashliba=hashlib.algorithms_available b=hashlib.algorithms_guaranteedprint(a)print(b)

        下面我們挑選常用的集中算法來進行講解


        一、MD5

        MD5即Message-Digest Algorithm 5(信息-摘要算法5),用于確保信息傳輸完整一致。是計算機廣泛使用的雜湊算法之一(又譯摘要算法、哈希算法),主流編程語言普遍已有MD5實現(xiàn)。將數(shù)據(jù)(如漢字)運算為另一固定長度值,是雜湊算法的基礎(chǔ)原理,MD5的前身有MD2、MD3和MD4。

        MD5算法具有以下特點:

        1、壓縮性:任意長度的數(shù)據(jù),算出的MD5值長度都是固定的。

        2、容易計算:從原數(shù)據(jù)計算出MD5值很容易。

        3、抗修改性:對原數(shù)據(jù)進行任何改動,哪怕只修改1個字節(jié),所得到的MD5值都有很大區(qū)別。

        4、強抗碰撞:已知原數(shù)據(jù)和其MD5值,想找到一個具有相同MD5值的數(shù)據(jù)(即偽造數(shù)據(jù))是非常困難的。

        MD5的作用是讓大容量信息在用數(shù)字簽名軟件簽署私人密鑰前被"壓縮"成一種保密的格式(就是把一個任意長度的字節(jié)串變換成一定長的十六進制數(shù)字串)。MD5是最常見的摘要算法,速度很快,生成結(jié)果是固定的128 bit字節(jié),通常用一個32位的16進制字符串表示。

        import hashlibstring='任性的90后boy'md5 = hashlib.md5() md5.update(string.encode('utf-8'))#轉(zhuǎn)碼,update里的必須是字節(jié)型res = md5.hexdigest() #返回字符型摘要信息print(md5.digest())#返回字節(jié)型的摘要信息print("md5加密結(jié)果:",res)


        二、sha1

        安全散列算法,SHA1的結(jié)果是160 bit字節(jié),通常用一個40位的16進制字符串表示

        import hashlibstring='任性的90后boy'sha1 = hashlib.sha1()sha1.update(string.encode('utf-8'))res = sha1.hexdigest()print("sha1加密結(jié)果:",res)


        三、sha224

        安全散列算法

        import hashlibstring='任性的90后boy'sha224 = hashlib.sha224()sha224.update(string.encode('utf-8'))res = sha224.hexdigest()print("sha224加密結(jié)果:",res)


        四、sha256

        安全散列算法

        import hashlibstring='任性的90后boy'sha256 = hashlib.sha256()sha256.update(string.encode('utf-8'))res = sha256.hexdigest()print("sha256加密結(jié)果:",res)


        五、sha384

        安全散列算法

        import hashlibstring='任性的90后boy'sha384 = hashlib.sha384()sha384.update(string.encode('utf-8'))res = sha384.hexdigest()print("sha384加密結(jié)果:",res)


        六、sha512

        安全散列算法

        import hashlibstring='任性的90后boy'sha512= hashlib.sha512()sha512.update(string.encode('utf-8'))res = sha512.hexdigest()print("sha512加密結(jié)果:",res)


        七、高級加密

        以上加密算法雖然依然非常厲害,但時候存在缺陷,即:通過撞庫可以反解

        所以,有必要對加密算法中添加自定義 key 再來做加密

        md5 = hashlib.md5()md5.update('md5'.encode('utf-8'))res = md5.hexdigest()print("普通加密:",res)md51 = hashlib.md5(b'md512')md51.update('md51'.encode('utf-8'))res = md51.hexdigest()print("采用key加密:",res)


        總結(jié)

        好了,今天就跟大家說這么多,主要給大家介紹了 md5、sha1、sha224、sha256、sha384、sha512 和高級加密等集中算法,簡單介紹了每個算法的特點和使用方法,后續(xù)精彩敬請期待!


        瀏覽 34
        點贊
        評論
        收藏
        分享

        手機掃一掃分享

        分享
        舉報
        評論
        圖片
        表情
        推薦
        點贊
        評論
        收藏
        分享

        手機掃一掃分享

        分享
        舉報
        1. <strong id="7actg"></strong>
        2. <table id="7actg"></table>

        3. <address id="7actg"></address>
          <address id="7actg"></address>
          1. <object id="7actg"><tt id="7actg"></tt></object>
            欧美sesese | 国产精品久久久久久久久久嫩草 | 国产精品亚洲区 | 女人高潮69xxxx | 亚洲少妇激情网 | 污视频国产| 国内精品视频在线 | 人人妻人人澡人人爽久久av | 淫荡无码 | 亚洲无码看片 |