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


Python DES3.new方法代碼示例

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


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

示例1: decrypt

# 需要導入模塊: from Crypto.Cipher import DES3 [as 別名]
# 或者: from Crypto.Cipher.DES3 import new [as 別名]
def decrypt(cls, key, keyusage, ciphertext):
        if len(ciphertext) < 24:
            raise ValueError('ciphertext too short')
        cksum, basic_ctext = ciphertext[:16], ciphertext[16:]
        ki = HMAC.new(key.contents, cls.usage_str(keyusage), MD5).digest()
        ke = HMAC.new(ki, cksum, MD5).digest()
        basic_plaintext = ARC4.new(ke).decrypt(basic_ctext)
        exp_cksum = HMAC.new(ki, basic_plaintext, MD5).digest()
        ok = _mac_equal(cksum, exp_cksum)
        if not ok and keyusage == 9:
            # Try again with usage 8, due to RFC 4757 errata.
            ki = HMAC.new(key.contents, pack('<I', 8), MD5).digest()
            exp_cksum = HMAC.new(ki, basic_plaintext, MD5).digest()
            ok = _mac_equal(cksum, exp_cksum)
        if not ok:
            raise InvalidChecksum('ciphertext integrity failure')
        # Discard the confounder.
        return basic_plaintext[8:] 
開發者ID:joxeankoret,項目名稱:CVE-2017-7494,代碼行數:20,代碼來源:crypto.py

示例2: messy_split

# 需要導入模塊: from Crypto.Cipher import DES3 [as 別名]
# 或者: from Crypto.Cipher.DES3 import new [as 別名]
def messy_split(long_line):
    # this is a messy way to split the data but it works for now.
    '''
    Split on = gives me the right sections but deletes the b64 padding
    use modulo math to restore padding.
    return new list.
    '''
    new_list = []
    old_list = long_line.split('=')
    for line in old_list:
        if len(line) != 0:
            line += "=" * ((4 - len(line) % 4) % 4)
            new_list.append(line)
    return new_list

# AES Decrypt 
開發者ID:opensourcesec,項目名稱:CIRTKit,代碼行數:18,代碼來源:jrat.py

示例3: rc4_encrypt

# 需要導入模塊: from Crypto.Cipher import DES3 [as 別名]
# 或者: from Crypto.Cipher.DES3 import new [as 別名]
def rc4_encrypt(self, key: str, hex_key: bool = False):
        """Encrypt raw state with RC4
        
        Args:
            key (str): Required. Secret key
            hex_key (bool, optional): If key is in hex. Defaults to False.
        
        Returns:
            Chepy: The Chepy object. 

        Examples:
            >>> Chepy("some data").rc4_encrypt("736563726574", hex_key=True).o
            b"9e59bf79a2c0b7d253"
        """
        if hex_key:
            key = binascii.unhexlify(key)
        if isinstance(key, str):
            key = key.encode()
        cipher = ARC4.new(key)
        self.state = binascii.hexlify(cipher.encrypt(self._convert_to_bytes()))
        return self 
開發者ID:securisec,項目名稱:chepy,代碼行數:23,代碼來源:encryptionencoding.py

示例4: rc4_decrypt

# 需要導入模塊: from Crypto.Cipher import DES3 [as 別名]
# 或者: from Crypto.Cipher.DES3 import new [as 別名]
def rc4_decrypt(self, key: str, hex_key: bool = False):
        """Decrypt raw state with RC4
        
        Args:
            key (str): Required. Secret key
            hex_key (bool, optional): If key is in hex. Defaults to False.
        
        Returns:
            Chepy: The Chepy object. 

        Examples:
            >>> Chepy("9e59bf79a2c0b7d253").hex_to_str().rc4_decrypt("secret").o
            b"some data"
        """
        if hex_key:
            key = binascii.unhexlify(key)
        if isinstance(key, str):
            key = key.encode()
        cipher = ARC4.new(key)
        self.state = cipher.decrypt(self._convert_to_bytes())
        return self 
開發者ID:securisec,項目名稱:chepy,代碼行數:23,代碼來源:encryptionencoding.py

示例5: encryption_oracle_aes

# 需要導入模塊: from Crypto.Cipher import DES3 [as 別名]
# 或者: from Crypto.Cipher.DES3 import new [as 別名]
def encryption_oracle_aes(payload):
    global constant, prefix_len, suffix_len, secret
    if secret:
        if constant:
            payload = random_bytes(prefix_len) + payload + secret
        else:
            payload = random_bytes(random.randint(1, 50)) + payload + secret
    else:
        if constant:
            payload = random_bytes(prefix_len) + payload + random_bytes(suffix_len)
        else:
            payload = random_bytes(random.randint(1, 50)) + payload + random_bytes(random.randint(1, 50))

    payload = add_padding(payload, AES.block_size)
    cipher = AES.new(key_AES, AES.MODE_ECB)
    return cipher.encrypt(payload) 
開發者ID:GrosQuildu,項目名稱:CryptoAttacks,代碼行數:18,代碼來源:test_ecb.py

示例6: encryption_oracle_des

# 需要導入模塊: from Crypto.Cipher import DES3 [as 別名]
# 或者: from Crypto.Cipher.DES3 import new [as 別名]
def encryption_oracle_des(payload):
    global constant, prefix_len, suffix_len, secret
    if secret:
        if constant:
            payload = random_bytes(prefix_len) + payload + secret
        else:
            payload = random_bytes(random.randint(1, 50)) + payload + secret
    else:
        if constant:
            payload = random_bytes(prefix_len) + payload + random_bytes(suffix_len)
        else:
            payload = random_bytes(random.randint(1, 50)) + payload + random_bytes(random.randint(1, 50))

    payload = add_padding(payload, DES3.block_size)
    cipher = DES3.new(key_DES3, DES3.MODE_ECB)
    return cipher.encrypt(payload) 
開發者ID:GrosQuildu,項目名稱:CryptoAttacks,代碼行數:18,代碼來源:test_ecb.py

示例7: SignWith3Des

# 需要導入模塊: from Crypto.Cipher import DES3 [as 別名]
# 或者: from Crypto.Cipher.DES3 import new [as 別名]
def SignWith3Des(src):
    # 首先對字符串取MD5
    raw_buf = hashlib.md5(src.encode()).digest()
    # 對16字節的md5做bcd2ascii
    bcd_to_ascii = bytearray(32)
    for i in range(len(raw_buf)):
        bcd_to_ascii[2*i]   = raw_buf[i]>>4
        bcd_to_ascii[2*i+1] = raw_buf[i] & 0xf
    # hex_to_bin轉換加密key
    key = bytes.fromhex('3ECA2F6FFA6D4952ABBACA5A7B067D23')
    # 對32字節的bcd_to_ascii做Triple DES加密(3DES/ECB/NoPadding)
    des3 = DES3.new(key, DES3.MODE_ECB)
    enc_bytes = des3.encrypt(bcd_to_ascii)
    # bin_to_hex得到最終加密結果
    enc_buf = ''.join(["%02X" % x for x in enc_bytes]).strip()
    return enc_buf

# 根據svrid查詢client_msg_id 
開發者ID:wechat-tests,項目名稱:PyMicroChat,代碼行數:20,代碼來源:Util.py

示例8: decrypt3DES

# 需要導入模塊: from Crypto.Cipher import DES3 [as 別名]
# 或者: from Crypto.Cipher.DES3 import new [as 別名]
def decrypt3DES(self, globalSalt, masterPassword, entrySalt, encryptedData):
        hp = sha1(globalSalt + masterPassword).digest()
        pes = entrySalt + '\x00' * (20 - len(entrySalt))
        chp = sha1(hp + entrySalt).digest()
        k1 = hmac.new(chp, pes + entrySalt, sha1).digest()
        tk = hmac.new(chp, pes, sha1).digest()
        k2 = hmac.new(chp, tk + entrySalt, sha1).digest()
        k = k1 + k2
        iv = k[-8:]
        key = k[:24]

        return DES3.new(key, DES3.MODE_CBC, iv).decrypt(encryptedData) 
開發者ID:mehulj94,項目名稱:Radium,代碼行數:14,代碼來源:Mozilla.py

示例9: aes

# 需要導入模塊: from Crypto.Cipher import DES3 [as 別名]
# 或者: from Crypto.Cipher.DES3 import new [as 別名]
def aes(self):
        return AES.new(self.key, AES.MODE_ECB) # 初始化加密器 
開發者ID:inlike,項目名稱:R-A-M-D-D3-S-M-H,代碼行數:4,代碼來源:RSA-AES-MD5-DES-DES3-MD5-SHA-HMAC.py

示例10: encrypt

# 需要導入模塊: from Crypto.Cipher import DES3 [as 別名]
# 或者: from Crypto.Cipher.DES3 import new [as 別名]
def encrypt(self, text):
        """
        傳入明文
        :param text:bytes類型,長度是KEY的倍數
        :return:
        """
        if not isinstance(text, bytes):
            text = bytes(text, 'utf-8')
        x = len(text) % 8
        text = text+b'\0'*x
        cryptor = DES3.new(self.key, self.mode)
        ciphertext = cryptor.encrypt(text)
        return ciphertext 
開發者ID:inlike,項目名稱:R-A-M-D-D3-S-M-H,代碼行數:15,代碼來源:RSA-AES-MD5-DES-DES3-MD5-SHA-HMAC.py

示例11: decrypt

# 需要導入模塊: from Crypto.Cipher import DES3 [as 別名]
# 或者: from Crypto.Cipher.DES3 import new [as 別名]
def decrypt(self, text):
        cryptor = DES3.new(self.key, self.mode)
        plain_text = cryptor.decrypt(text)
        st = str(plain_text.decode("utf-8")).rstrip('\0')
        return st 
開發者ID:inlike,項目名稱:R-A-M-D-D3-S-M-H,代碼行數:7,代碼來源:RSA-AES-MD5-DES-DES3-MD5-SHA-HMAC.py

示例12: USE_HMAC

# 需要導入模塊: from Crypto.Cipher import DES3 [as 別名]
# 或者: from Crypto.Cipher.DES3 import new [as 別名]
def USE_HMAC(key, text):
    if not isinstance(key, bytes):
        key = bytes(key, 'utf-8')
    if not isinstance(text, bytes):
        text = bytes(text, 'utf-8')
    h = hmac.new(key, text, digestmod='MD5')
    return h.hexdigest() 
開發者ID:inlike,項目名稱:R-A-M-D-D3-S-M-H,代碼行數:9,代碼來源:RSA-AES-MD5-DES-DES3-MD5-SHA-HMAC.py

示例13: decrypt_xor

# 需要導入模塊: from Crypto.Cipher import DES3 [as 別名]
# 或者: from Crypto.Cipher.DES3 import new [as 別名]
def decrypt_xor(key, data):
    cipher = XOR.new(key)
    return cipher.decrypt(data)


# RC4 
開發者ID:kevthehermit,項目名稱:RATDecoders,代碼行數:8,代碼來源:crypto.py

示例14: decrypt_arc4

# 需要導入模塊: from Crypto.Cipher import DES3 [as 別名]
# 或者: from Crypto.Cipher.DES3 import new [as 別名]
def decrypt_arc4(key, data):
    cipher = ARC4.new(key)
    return cipher.decrypt(data)


# DES 
開發者ID:kevthehermit,項目名稱:RATDecoders,代碼行數:8,代碼來源:crypto.py

示例15: decrypt_des_ecb

# 需要導入模塊: from Crypto.Cipher import DES3 [as 別名]
# 或者: from Crypto.Cipher.DES3 import new [as 別名]
def decrypt_des_ecb(key, data, iv=None):
    mode = DES.MODE_ECB
    if iv:
        cipher = DES.new(key, mode, iv)
    else:
        cipher = DES.new(key, mode)
    return cipher.decrypt(data) 
開發者ID:kevthehermit,項目名稱:RATDecoders,代碼行數:9,代碼來源:crypto.py


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