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


Python Cipher.AES屬性代碼示例

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


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

示例1: runTest

# 需要導入模塊: from Crypto import Cipher [as 別名]
# 或者: from Crypto.Cipher import AES [as 別名]
def runTest(self):
        "Simple test of AllOrNothing"

        from Crypto.Cipher import AES
        import base64

        # The current AllOrNothing will fail
        # every so often. Repeat the test
        # several times to force this.
        for i in range(50):
            x = AllOrNothing.AllOrNothing(AES)

            msgblocks = x.digest(text)
            
            # get a new undigest-only object so there's no leakage
            y = AllOrNothing.AllOrNothing(AES)
            text2 = y.undigest(msgblocks)
            self.assertEqual(text, text2) 
開發者ID:mortcanty,項目名稱:earthengine,代碼行數:20,代碼來源:test_AllOrNothing.py

示例2: _AESUnwrap

# 需要導入模塊: from Crypto import Cipher [as 別名]
# 或者: from Crypto.Cipher import AES [as 別名]
def _AESUnwrap(kek, wrapped):
    C = []
    for i in range(len(wrapped)//8):
        C.append(_unpack64bit(wrapped[i * 8:i * 8 + 8]))
    n = len(C) - 1
    R = [0] * (n+1)
    A = C[0]

    for i in range(1, n+1):
        R[i] = C[i]

    for j in reversed(range(0, 6)):
        for i in reversed(range(1, n+1)):
            todec = _pack64bit(A ^ (n * j + i))
            todec += _pack64bit(R[i])
            B = Crypto.Cipher.AES.new(kek, Crypto.Cipher.AES.MODE_ECB).decrypt(todec)
            A = _unpack64bit(B[:8])
            R[i] = _unpack64bit(B[8:])

    if A != 0xa6a6a6a6a6a6a6a6:
        return None
    res = b"".join(map(_pack64bit, R[1:]))
    return res 
開發者ID:jfarley248,項目名稱:iTunes_Backup_Reader,代碼行數:25,代碼來源:google_iphone_dataprotection.py

示例3: setSessionKey

# 需要導入模塊: from Crypto import Cipher [as 別名]
# 或者: from Crypto.Cipher import AES [as 別名]
def setSessionKey( self, key, iv ):
        """
        Set AES' session key and the initialisation vector for counter mode.

        The given `key' and `iv' are used as 256-bit AES key and as 128-bit
        initialisation vector for counter mode.  Both, the key as well as the
        IV must come from a CSPRNG.
        """

        self.sessionKey = key

        # Our 128-bit counter has the following format:
        # [ 64-bit static and random IV ] [ 64-bit incrementing counter ]
        # Counter wrapping is not allowed which makes it possible to transfer
        # 2^64 * 16 bytes of data while avoiding counter reuse.  That amount is
        # effectively out of reach given today's networking performance.
        log.debug("Setting IV for AES-CTR.")
        self.counter = Crypto.Util.Counter.new(64,
                                               prefix = iv,
                                               initial_value = 1,
                                               allow_wraparound = False)

        log.debug("Setting session key for AES-CTR.")
        self.crypter = Crypto.Cipher.AES.new(key, Crypto.Cipher.AES.MODE_CTR,
                                             counter=self.counter) 
開發者ID:proxysh,項目名稱:Safejumper-for-Desktop,代碼行數:27,代碼來源:mycrypto.py

示例4: encrypt_aes

# 需要導入模塊: from Crypto import Cipher [as 別名]
# 或者: from Crypto.Cipher import AES [as 別名]
def encrypt_aes(plaintext, key, padding=chr(0)):
    """
    AES-256-OCB encryption

    `Requires`
    :param str plaintext:   plain text/data
    :param str key:         session encryption key

    `Optional`
    :param str padding:     default: (null byte)

    Returns encrypted ciphertext as base64-encoded string

    """
    cipher = Crypto.Cipher.AES.new(key, Crypto.Cipher.AES.MODE_OCB)
    ciphertext, tag = cipher.encrypt_and_digest(plaintext)
    output = b''.join((cipher.nonce, tag, ciphertext))
    return base64.b64encode(output) 
開發者ID:malwaredllc,項目名稱:byob,代碼行數:20,代碼來源:ransom.py

示例5: decrypt_aes

# 需要導入模塊: from Crypto import Cipher [as 別名]
# 或者: from Crypto.Cipher import AES [as 別名]
def decrypt_aes(ciphertext, key, padding=chr(0)):
    """
    AES-256-OCB decryption

    `Requires`
    :param str ciphertext:  encrypted block of data
    :param str key:         session encryption key

    `Optional`
    :param str padding:     default: (null byte)

    Returns decrypted plaintext as string

    """
    data = StringIO(base64.b64decode(ciphertext))
    nonce, tag, ciphertext = [ data.read(x) for x in (Crypto.Cipher.AES.block_size - 1, Crypto.Cipher.AES.block_size, -1) ]
    cipher = Crypto.Cipher.AES.new(key, Crypto.Cipher.AES.MODE_OCB, nonce)
    return cipher.decrypt_and_verify(ciphertext, tag) 
開發者ID:malwaredllc,項目名稱:byob,代碼行數:20,代碼來源:ransom.py

示例6: decrypt_file

# 需要導入模塊: from Crypto import Cipher [as 別名]
# 或者: from Crypto.Cipher import AES [as 別名]
def decrypt_file(filename, key):
    """
    Decrypt a file that was encrypted with AES-256-OCB encryption

    `Required`
    :param str filename:    target filename
    :param str aes_key:     256-bit key

    Returns True if succesful, otherwise False

    """
    try:
        if os.path.isfile(filename):
            with open(filename, 'rb') as fp:
                ciphertext = fp.read()
            plaintext = decrypt_aes(ciphertext, key)
            with open(filename, 'wb') as fd:
                fd.write(plaintext)
            util.log('{} decrypted'.format(filename))
            return True
        else:
            util.log("File '{}' not found".format(filename))
    except Exception as e:
        util.log("{} error: {}".format(decrypt_file.__name__, str(e)))
    return False 
開發者ID:malwaredllc,項目名稱:byob,代碼行數:27,代碼來源:ransom.py

示例7: test_internal_caching

# 需要導入模塊: from Crypto import Cipher [as 別名]
# 或者: from Crypto.Cipher import AES [as 別名]
def test_internal_caching(self):
        """Verify that internal caching is implemented correctly"""

        data_to_mac = get_tag_random("data_to_mac", 128)
        key = get_tag_random("key", 16)
        ref_mac = CMAC.new(key, msg=data_to_mac, ciphermod=AES).digest()

        # Break up in chunks of different length
        # The result must always be the same
        for chunk_length in 1, 2, 3, 7, 10, 13, 16, 40, 80, 128:

            chunks = [data_to_mac[i:i+chunk_length] for i in
                      range(0, len(data_to_mac), chunk_length)]

            mac = CMAC.new(key, ciphermod=AES)
            for chunk in chunks:
                mac.update(chunk)
            self.assertEqual(ref_mac, mac.digest()) 
開發者ID:vcheckzen,項目名稱:FODI,代碼行數:20,代碼來源:test_CMAC.py

示例8: test_update_after_digest

# 需要導入模塊: from Crypto import Cipher [as 別名]
# 或者: from Crypto.Cipher import AES [as 別名]
def test_update_after_digest(self):
        msg = b"rrrrttt"
        key = b"4" * 16

        # Normally, update() cannot be done after digest()
        h = CMAC.new(key, msg[:4], ciphermod=AES)
        dig1 = h.digest()
        self.assertRaises(TypeError, h.update, msg[4:])
        dig2 = CMAC.new(key, msg, ciphermod=AES).digest()

        # With the proper flag, it is allowed
        h2 = CMAC.new(key, msg[:4], ciphermod=AES, update_after_digest=True)
        self.assertEquals(h2.digest(), dig1)
        # ... and the subsequent digest applies to the entire message
        # up to that point
        h2.update(msg[4:])
        self.assertEquals(h2.digest(), dig2) 
開發者ID:vcheckzen,項目名稱:FODI,代碼行數:19,代碼來源:test_CMAC.py

示例9: runTest

# 需要導入模塊: from Crypto import Cipher [as 別名]
# 或者: from Crypto.Cipher import AES [as 別名]
def runTest(self):

        key = b"0" * 16
        data = b"\x00\x01\x02"

        # Data and key can be a bytearray (during initialization)
        key_ba = bytearray(key)
        data_ba = bytearray(data)

        h1 = CMAC.new(key, data, ciphermod=AES)
        h2 = CMAC.new(key_ba, data_ba, ciphermod=AES)
        key_ba[:1] = b'\xFF'
        data_ba[:1] = b'\xFF'
        self.assertEqual(h1.digest(), h2.digest())

        # Data can be a bytearray (during operation)
        key_ba = bytearray(key)
        data_ba = bytearray(data)

        h1 = CMAC.new(key, ciphermod=AES)
        h2 = CMAC.new(key, ciphermod=AES)
        h1.update(data)
        h2.update(data_ba)
        data_ba[:1] = b'\xFF'
        self.assertEqual(h1.digest(), h2.digest()) 
開發者ID:vcheckzen,項目名稱:FODI,代碼行數:27,代碼來源:test_CMAC.py

示例10: parse_sha1_ctx

# 需要導入模塊: from Crypto import Cipher [as 別名]
# 或者: from Crypto.Cipher import AES [as 別名]
def parse_sha1_ctx(ctx, winver):
    if not (winver in CNG_STRUCTURES):
        raise Exception('Unsupported Windows version: %d' % winver)
    ofs = CNG_STRUCTURES[winver]['SHA1']
    ofs_state = ofs['state']
    ofs_buffer = ofs['buffer']
    ofs_size = ofs['size']
    # sha1 state is at offset 0x40 for win7 and is 20 bytes long
    sha1_state = ctx[ofs_state:ofs_state + 0x14]
    # Check sha1_ctx is still in initial state (i.e. no Sha1Transform yet)
    if sha1_state != struct.pack('<LLLLL', 0x67452301, 0x0EFCDAB89, 0x98BADCFE, 0x10325476, 0x0C3D2E1F0):
        return None
    seed_size = struct.unpack('<L', ctx[ofs_size:ofs_size+4])[0]
    return ctx[ofs_buffer:ofs_buffer+seed_size]

# Extract the key from the AES key schedule
# The raw AES key is xor'ed into the plaintext at the start of the first round, i.e. it is
# the very first (of 11 for AES128) subkeys 
開發者ID:eleemosynator,項目名稱:writeups,代碼行數:20,代碼來源:dpapi.py

示例11: AESdecryptCBC

# 需要導入模塊: from Crypto import Cipher [as 別名]
# 或者: from Crypto.Cipher import AES [as 別名]
def AESdecryptCBC(data, key, iv=b"\x00" * 16):
    if len(data) % 16:
        print("WARN: AESdecryptCBC: data length not /16, truncating")
        data = data[0:(len(data)/16) * 16]
    data = Crypto.Cipher.AES.new(key, Crypto.Cipher.AES.MODE_CBC, iv).decrypt(data)
    return data 
開發者ID:jfarley248,項目名稱:iTunes_Backup_Reader,代碼行數:8,代碼來源:google_iphone_dataprotection.py

示例12: __init__

# 需要導入模塊: from Crypto import Cipher [as 別名]
# 或者: from Crypto.Cipher import AES [as 別名]
def __init__( self ):
        """
        Initialise a PayloadCrypter object.
        """

        log.debug("Initialising AES-CTR instance.")

        self.sessionKey = None
        self.crypter = None
        self.counter = None 
開發者ID:proxysh,項目名稱:Safejumper-for-Desktop,代碼行數:12,代碼來源:mycrypto.py

示例13: encrypt

# 需要導入模塊: from Crypto import Cipher [as 別名]
# 或者: from Crypto.Cipher import AES [as 別名]
def encrypt( self, data ):
        """
        Encrypts the given `data' using AES in counter mode.
        """

        return self.crypter.encrypt(data)

    # Encryption equals decryption in AES-CTR. 
開發者ID:proxysh,項目名稱:Safejumper-for-Desktop,代碼行數:10,代碼來源:mycrypto.py

示例14: new

# 需要導入模塊: from Crypto import Cipher [as 別名]
# 或者: from Crypto.Cipher import AES [as 別名]
def new(key):
        cipher = Crypto.Cipher.AES.new(bytes(key))
        def encrypt(plaintext):
            return bytearray(cipher.encrypt(bytes(plaintext)))
        return AESGCM(key, "pycrypto", encrypt) 
開發者ID:scalyr,項目名稱:scalyr-agent-2,代碼行數:7,代碼來源:pycrypto_aesgcm.py

示例15: load_crypto_libraries

# 需要導入模塊: from Crypto import Cipher [as 別名]
# 或者: from Crypto.Cipher import AES [as 別名]
def load_crypto_libraries():
    global aes256_cbc_decrypt, aes256_ofb_decrypt, pbkdf2
    try:
        import Crypto.Cipher.AES, Crypto.Protocol.KDF
        aes256_cbc_decrypt = lambda key, iv, ciphertext: \
            Crypto.Cipher.AES.new(key, Crypto.Cipher.AES.MODE_CBC, iv).decrypt(ciphertext)
        aes256_ofb_decrypt = lambda key, iv, ciphertext: \
            Crypto.Cipher.AES.new(key, Crypto.Cipher.AES.MODE_OFB, iv).decrypt(ciphertext)
        pbkdf2 = lambda password, salt, iter_count, len: \
            Crypto.Protocol.KDF.PBKDF2(password, salt, len, iter_count)
        return
    except ImportError: pass

    # The pure python AES library is attributed to GitHub user serprex; please see the
    # aespython README.txt for more information.
    #
    # Add the parent directory of this script's location to the library search path
    sys.path.append(os.path.join(os.path.dirname(os.path.realpath(__file__)), ".."))
    import aespython
    #
    expandKey = aespython.key_expander.expandKey
    def aes256_decrypt_factory(BlockMode):
        def aes256_decrypt(key, iv, ciphertext):
            block_cipher  = aespython.aes_cipher.AESCipher( expandKey(bytearray(key)) )
            stream_cipher = BlockMode(block_cipher, 16)
            stream_cipher.set_iv(bytearray(iv))
            plaintext = bytearray()
            for i in xrange(0, len(ciphertext), 16):
                plaintext.extend( stream_cipher.decrypt_block(bytearray(ciphertext[i:i+16])) )
            return str(plaintext)
        return aes256_decrypt
    aes256_cbc_decrypt = aes256_decrypt_factory(aespython.cbc_mode.CBCMode)
    aes256_ofb_decrypt = aes256_decrypt_factory(aespython.ofb_mode.OFBMode)

    import passlib.utils.pbkdf2
    pbkdf2 = passlib.utils.pbkdf2.pbkdf2


################################### Main ################################### 
開發者ID:gurnec,項目名稱:btcrecover,代碼行數:41,代碼來源:extract-blockchain-second-hash.py


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