當前位置: 首頁>>代碼示例>>Python>>正文


Python HMAC.new方法代碼示例

本文整理匯總了Python中Cryptodome.Hash.HMAC.new方法的典型用法代碼示例。如果您正苦於以下問題:Python HMAC.new方法的具體用法?Python HMAC.new怎麽用?Python HMAC.new使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在Cryptodome.Hash.HMAC的用法示例。


在下文中一共展示了HMAC.new方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: encrypt

# 需要導入模塊: from Cryptodome.Hash import HMAC [as 別名]
# 或者: from Cryptodome.Hash.HMAC import new [as 別名]
def encrypt(self, plaintext, esn):
        """
        Encrypt the given Plaintext with the encryption key
        :param plaintext:
        :return: Serialized JSON String of the encryption Envelope
        """
        init_vector = get_random_bytes(16)
        cipher = AES.new(self.encryption_key, AES.MODE_CBC, init_vector)
        ciphertext = base64.standard_b64encode(
            cipher.encrypt(Padding.pad(plaintext.encode('utf-8'), 16))).decode('utf-8')
        encryption_envelope = {
            'ciphertext': ciphertext,
            'keyid': '_'.join((esn, str(self.sequence_number))),
            'sha256': 'AA==',
            'iv': base64.standard_b64encode(init_vector).decode('utf-8')
        }
        return json.dumps(encryption_envelope) 
開發者ID:CastagnaIT,項目名稱:plugin.video.netflix,代碼行數:19,代碼來源:default_crypto.py

示例2: encrypt_file

# 需要導入模塊: from Cryptodome.Hash import HMAC [as 別名]
# 或者: from Cryptodome.Hash.HMAC import new [as 別名]
def encrypt_file(file, keys=secretKeys()):
    '''Encrypt file data with the same method as the Send browser/js client'''
    key = keys.encryptKey
    iv = keys.encryptIV
    encData = tempfile.SpooledTemporaryFile(max_size=SPOOL_SIZE, mode='w+b')
    cipher = Cryptodome.Cipher.AES.new(key, Cryptodome.Cipher.AES.MODE_GCM, iv)

    pbar = progbar(fileSize(file))

    for chunk in iter(lambda: file.read(CHUNK_SIZE), b''):
        encData.write(cipher.encrypt(chunk))
        pbar.update(len(chunk))

    pbar.close()
    encData.write(cipher.digest())
    file.close()

    encData.seek(0)
    return encData 
開發者ID:ehuggett,項目名稱:send-cli,代碼行數:21,代碼來源:upload.py

示例3: __decryptHash

# 需要導入模塊: from Cryptodome.Hash import HMAC [as 別名]
# 或者: from Cryptodome.Hash.HMAC import new [as 別名]
def __decryptHash(self, rid, cryptedHash, constant, newStyle = False):
        # Section 2.2.11.1.1 Encrypting an NT or LM Hash Value with a Specified Key
        # plus hashedBootKey stuff
        Key1,Key2 = self.__cryptoCommon.deriveKey(rid)

        Crypt1 = DES.new(Key1, DES.MODE_ECB)
        Crypt2 = DES.new(Key2, DES.MODE_ECB)

        if newStyle is False:
            rc4Key = self.MD5( self.__hashedBootKey[:0x10] + pack("<L",rid) + constant )
            rc4 = ARC4.new(rc4Key)
            key = rc4.encrypt(cryptedHash['Hash'])
        else:
            key = self.__cryptoCommon.decryptAES(self.__hashedBootKey[:0x10], cryptedHash['Hash'], cryptedHash['Salt'])[:16]

        decryptedHash = Crypt1.decrypt(key[:8]) + Crypt2.decrypt(key[8:])

        return decryptedHash 
開發者ID:Ridter,項目名稱:Exchange2domain,代碼行數:20,代碼來源:dump.py

示例4: __decryptSecret

# 需要導入模塊: from Cryptodome.Hash import HMAC [as 別名]
# 或者: from Cryptodome.Hash.HMAC import new [as 別名]
def __decryptSecret(self, key, value):
        # [MS-LSAD] Section 5.1.2
        plainText = ''

        encryptedSecretSize = unpack('<I', value[:4])[0]
        value = value[len(value)-encryptedSecretSize:]

        key0 = key
        for i in range(0, len(value), 8):
            cipherText = value[:8]
            tmpStrKey = key0[:7]
            tmpKey = self.__cryptoCommon.transformKey(tmpStrKey)
            Crypt1 = DES.new(tmpKey, DES.MODE_ECB)
            plainText += Crypt1.decrypt(cipherText)
            key0 = key0[7:]
            value = value[8:]
            # AdvanceKey
            if len(key0) < 7:
                key0 = key[len(key0):]

        secret = LSA_SECRET_XP(plainText)
        return secret['Secret'] 
開發者ID:Ridter,項目名稱:Exchange2domain,代碼行數:24,代碼來源:dump.py

示例5: __decryptLSA

# 需要導入模塊: from Cryptodome.Hash import HMAC [as 別名]
# 或者: from Cryptodome.Hash.HMAC import new [as 別名]
def __decryptLSA(self, value):
        if self.__vistaStyle is True:
            # ToDo: There could be more than one LSA Keys
            record = LSA_SECRET(value)
            tmpKey = self.__sha256(self.__bootKey, record['EncryptedData'][:32])
            plainText = self.__cryptoCommon.decryptAES(tmpKey, record['EncryptedData'][32:])
            record = LSA_SECRET_BLOB(plainText)
            self.__LSAKey = record['Secret'][52:][:32]

        else:
            md5 = hashlib.new('md5')
            md5.update(self.__bootKey)
            for i in range(1000):
                md5.update(value[60:76])
            tmpKey = md5.digest()
            rc4 = ARC4.new(tmpKey)
            plainText = rc4.decrypt(value[12:60])
            self.__LSAKey = plainText[0x10:0x20] 
開發者ID:Ridter,項目名稱:Exchange2domain,代碼行數:20,代碼來源:dump.py

示例6: __decryptSecret

# 需要導入模塊: from Cryptodome.Hash import HMAC [as 別名]
# 或者: from Cryptodome.Hash.HMAC import new [as 別名]
def __decryptSecret(self, key, value):
        # [MS-LSAD] Section 5.1.2
        plainText = ''

        encryptedSecretSize = unpack('<I', value[:4])[0]
        value = value[len(value)-encryptedSecretSize:]

        key0 = key
        for i in range(0, len(value), 8):
            cipherText = value[:8]
            tmpStrKey = key0[:7]
            tmpKey = transformKey(tmpStrKey)
            Crypt1 = DES.new(tmpKey, DES.MODE_ECB)
            plainText += Crypt1.decrypt(cipherText)
            key0 = key0[7:]
            value = value[8:]
            # AdvanceKey
            if len(key0) < 7:
                key0 = key[len(key0):]

        secret = LSA_SECRET_XP(plainText)
        return secret['Secret'] 
開發者ID:Coalfire-Research,項目名稱:Slackor,代碼行數:24,代碼來源:secretsdump.py

示例7: calculateChecksum

# 需要導入模塊: from Cryptodome.Hash import HMAC [as 別名]
# 或者: from Cryptodome.Hash.HMAC import new [as 別名]
def calculateChecksum(data):
 """The function used to calculate CIC checksums for xpd files"""
 return HMAC.new(constants.cicKey, data, SHA256).hexdigest() 
開發者ID:ma1co,項目名稱:Sony-PMCA-RE,代碼行數:5,代碼來源:__init__.py

示例8: load_crypto_session

# 需要導入模塊: from Cryptodome.Hash import HMAC [as 別名]
# 或者: from Cryptodome.Hash.HMAC import new [as 別名]
def load_crypto_session(self, msl_data=None):
        try:
            self.encryption_key = base64.standard_b64decode(
                msl_data['encryption_key'])
            self.sign_key = base64.standard_b64decode(
                msl_data['sign_key'])
            if not self.encryption_key or not self.sign_key:
                raise MSLError('Missing encryption_key or sign_key')
            self.rsa_key = RSA.importKey(
                base64.standard_b64decode(msl_data['rsa_key']))
        except Exception:  # pylint: disable=broad-except
            common.debug('Generating new RSA keys')
            self.rsa_key = RSA.generate(2048)
            self.encryption_key = None
            self.sign_key = None 
開發者ID:CastagnaIT,項目名稱:plugin.video.netflix,代碼行數:17,代碼來源:default_crypto.py

示例9: decrypt

# 需要導入模塊: from Cryptodome.Hash import HMAC [as 別名]
# 或者: from Cryptodome.Hash.HMAC import new [as 別名]
def decrypt(self, init_vector, ciphertext):
        """Decrypt a ciphertext"""
        cipher = AES.new(self.encryption_key, AES.MODE_CBC, init_vector)
        return Padding.unpad(cipher.decrypt(ciphertext), 16) 
開發者ID:CastagnaIT,項目名稱:plugin.video.netflix,代碼行數:6,代碼來源:default_crypto.py

示例10: sign

# 需要導入模塊: from Cryptodome.Hash import HMAC [as 別名]
# 或者: from Cryptodome.Hash.HMAC import new [as 別名]
def sign(self, message):
        """Sign a message"""
        return base64.standard_b64encode(
            HMAC.new(self.sign_key, message.encode('utf-8'), SHA256).digest()).decode('utf-8') 
開發者ID:CastagnaIT,項目名稱:plugin.video.netflix,代碼行數:6,代碼來源:default_crypto.py

示例11: _init_keys

# 需要導入模塊: from Cryptodome.Hash import HMAC [as 別名]
# 或者: from Cryptodome.Hash.HMAC import new [as 別名]
def _init_keys(self, key_response_data):
        cipher = PKCS1_OAEP.new(self.rsa_key)
        encrypted_encryption_key = base64.standard_b64decode(
            key_response_data['keydata']['encryptionkey'])
        encrypted_sign_key = base64.standard_b64decode(
            key_response_data['keydata']['hmackey'])
        self.encryption_key = _decrypt_key(encrypted_encryption_key, cipher)
        self.sign_key = _decrypt_key(encrypted_sign_key, cipher) 
開發者ID:CastagnaIT,項目名稱:plugin.video.netflix,代碼行數:10,代碼來源:default_crypto.py

示例12: generate_session_key

# 需要導入模塊: from Cryptodome.Hash import HMAC [as 別名]
# 或者: from Cryptodome.Hash.HMAC import new [as 別名]
def generate_session_key(hmac_secret=b''):
    """
    :param hmac_secret: optional HMAC
    :type hmac_secret: :class:`bytes`
    :return: (session_key, encrypted_session_key) tuple
    :rtype: :class:`tuple`
    """
    session_key = random_bytes(32)
    encrypted_session_key = PKCS1_OAEP.new(UniverseKey.Public, SHA1)\
                                      .encrypt(session_key + hmac_secret)

    return (session_key, encrypted_session_key) 
開發者ID:ValvePython,項目名稱:steam,代碼行數:14,代碼來源:crypto.py

示例13: symmetric_encrypt_ecb

# 需要導入模塊: from Cryptodome.Hash import HMAC [as 別名]
# 或者: from Cryptodome.Hash.HMAC import new [as 別名]
def symmetric_encrypt_ecb(message, key):
    return AES.new(key, AES.MODE_ECB).encrypt(pad(message)) 
開發者ID:ValvePython,項目名稱:steam,代碼行數:4,代碼來源:crypto.py

示例14: symmetric_encrypt_iv

# 需要導入模塊: from Cryptodome.Hash import HMAC [as 別名]
# 或者: from Cryptodome.Hash.HMAC import new [as 別名]
def symmetric_encrypt_iv(iv, key):
    return AES.new(key, AES.MODE_ECB).encrypt(iv) 
開發者ID:ValvePython,項目名稱:steam,代碼行數:4,代碼來源:crypto.py

示例15: symmetric_encrypt_with_iv

# 需要導入模塊: from Cryptodome.Hash import HMAC [as 別名]
# 或者: from Cryptodome.Hash.HMAC import new [as 別名]
def symmetric_encrypt_with_iv(message, key, iv):
    encrypted_iv = symmetric_encrypt_iv(iv, key)
    cyphertext = AES.new(key, AES.MODE_CBC, iv).encrypt(pad(message))
    return encrypted_iv + cyphertext 
開發者ID:ValvePython,項目名稱:steam,代碼行數:6,代碼來源:crypto.py


注:本文中的Cryptodome.Hash.HMAC.new方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。