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


Python AES.process方法代碼示例

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


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

示例1: _crypt

# 需要導入模塊: from pycryptopp.cipher.aes import AES [as 別名]
# 或者: from pycryptopp.cipher.aes.AES import process [as 別名]
 def _crypt(self, offset, data):
     offset_big = offset // 16
     offset_small = offset % 16
     iv = binascii.unhexlify("%032x" % offset_big)
     cipher = AES(self.key, iv=iv)
     cipher.process("\x00"*offset_small)
     return cipher.process(data)
開發者ID:tahoe-lafs,項目名稱:tahoe-lafs,代碼行數:9,代碼來源:fileutil.py

示例2: _decrypt_rwcapdata

# 需要導入模塊: from pycryptopp.cipher.aes import AES [as 別名]
# 或者: from pycryptopp.cipher.aes.AES import process [as 別名]
 def _decrypt_rwcapdata(self, encwrcap):
     salt = encwrcap[:16]
     crypttext = encwrcap[16:-32]
     key = hashutil.mutable_rwcap_key_hash(salt, self._node.get_writekey())
     cryptor = AES(key)
     plaintext = cryptor.process(crypttext)
     return plaintext
開發者ID:ArtRichards,項目名稱:tahoe-lafs,代碼行數:9,代碼來源:dirnode.py

示例3: _decrypt

# 需要導入模塊: from pycryptopp.cipher.aes import AES [as 別名]
# 或者: from pycryptopp.cipher.aes.AES import process [as 別名]
 def _decrypt(self, crypttext, IV, readkey):
     self._status.set_status("decrypting")
     started = time.time()
     key = hashutil.ssk_readkey_data_hash(IV, readkey)
     decryptor = AES(key)
     plaintext = decryptor.process(crypttext)
     self._status.timings["decrypt"] = time.time() - started
     return plaintext
開發者ID:p-static,項目名稱:tahoe-lafs,代碼行數:10,代碼來源:retrieve.py

示例4: CiphertextDownloader

# 需要導入模塊: from pycryptopp.cipher.aes import AES [as 別名]
# 或者: from pycryptopp.cipher.aes.AES import process [as 別名]
class DecryptingConsumer:
    """I sit between a CiphertextDownloader (which acts as a Producer) and
    the real Consumer, decrypting everything that passes by. The real
    Consumer sees the real Producer, but the Producer sees us instead of the
    real consumer."""
    implements(IConsumer, IDownloadStatusHandlingConsumer)

    def __init__(self, consumer, readkey, offset):
        self._consumer = consumer
        self._read_ev = None
        self._download_status = None
        # TODO: pycryptopp CTR-mode needs random-access operations: I want
        # either a=AES(readkey, offset) or better yet both of:
        #  a=AES(readkey, offset=0)
        #  a.process(ciphertext, offset=xyz)
        # For now, we fake it with the existing iv= argument.
        offset_big = offset // 16
        offset_small = offset % 16
        iv = binascii.unhexlify("%032x" % offset_big)
        self._decryptor = AES(readkey, iv=iv)
        self._decryptor.process("\x00"*offset_small)

    def set_download_status_read_event(self, read_ev):
        self._read_ev = read_ev
    def set_download_status(self, ds):
        self._download_status = ds

    def registerProducer(self, producer, streaming):
        # this passes through, so the real consumer can flow-control the real
        # producer. Therefore we don't need to provide any IPushProducer
        # methods. We implement all the IConsumer methods as pass-throughs,
        # and only intercept write() to perform decryption.
        self._consumer.registerProducer(producer, streaming)
    def unregisterProducer(self):
        self._consumer.unregisterProducer()
    def write(self, ciphertext):
        started = now()
        plaintext = self._decryptor.process(ciphertext)
        if self._read_ev:
            elapsed = now() - started
            self._read_ev.update(0, elapsed, 0)
        if self._download_status:
            self._download_status.add_misc_event("AES", started, now())
        self._consumer.write(plaintext)
開發者ID:GunioRobot,項目名稱:tahoe-lafs,代碼行數:46,代碼來源:filenode.py

示例5: _encrypt_rw_uri

# 需要導入模塊: from pycryptopp.cipher.aes import AES [as 別名]
# 或者: from pycryptopp.cipher.aes.AES import process [as 別名]
def _encrypt_rw_uri(writekey, rw_uri):
    precondition(isinstance(rw_uri, str), rw_uri)
    precondition(isinstance(writekey, str), writekey)

    salt = hashutil.mutable_rwcap_salt_hash(rw_uri)
    key = hashutil.mutable_rwcap_key_hash(salt, writekey)
    cryptor = AES(key)
    crypttext = cryptor.process(rw_uri)
    mac = hashutil.hmac(key, salt + crypttext)
    assert len(mac) == 32
    return salt + crypttext + mac
開發者ID:ArtRichards,項目名稱:tahoe-lafs,代碼行數:13,代碼來源:dirnode.py

示例6: test_previous_upload_failed

# 需要導入模塊: from pycryptopp.cipher.aes import AES [as 別名]
# 或者: from pycryptopp.cipher.aes.AES import process [as 別名]
    def test_previous_upload_failed(self):
        self.basedir = "helper/AssistedUpload/test_previous_upload_failed"
        self.setUpHelper(self.basedir)

        # we want to make sure that an upload which fails (leaving the
        # ciphertext in the CHK_encoding/ directory) does not prevent a later
        # attempt to upload that file from working. We simulate this by
        # populating the directory manually. The hardest part is guessing the
        # storage index.

        k = FakeClient.DEFAULT_ENCODING_PARAMETERS["k"]
        n = FakeClient.DEFAULT_ENCODING_PARAMETERS["n"]
        max_segsize = FakeClient.DEFAULT_ENCODING_PARAMETERS["max_segment_size"]
        segsize = min(max_segsize, len(DATA))
        # this must be a multiple of 'required_shares'==k
        segsize = mathutil.next_multiple(segsize, k)

        key = hashutil.convergence_hash(k, n, segsize, DATA, "test convergence string")
        assert len(key) == 16
        encryptor = AES(key)
        SI = hashutil.storage_index_hash(key)
        SI_s = si_b2a(SI)
        encfile = os.path.join(self.basedir, "CHK_encoding", SI_s)
        f = open(encfile, "wb")
        f.write(encryptor.process(DATA))
        f.close()

        u = upload.Uploader(self.helper_furl)
        u.setServiceParent(self.s)

        d = wait_a_few_turns()

        def _ready(res):
            assert u._helper
            return upload_data(u, DATA, convergence="test convergence string")

        d.addCallback(_ready)

        def _uploaded(results):
            the_uri = results.get_uri()
            assert "CHK" in the_uri

        d.addCallback(_uploaded)

        def _check_empty(res):
            files = os.listdir(os.path.join(self.basedir, "CHK_encoding"))
            self.failUnlessEqual(files, [])
            files = os.listdir(os.path.join(self.basedir, "CHK_incoming"))
            self.failUnlessEqual(files, [])

        d.addCallback(_check_empty)

        return d
開發者ID:zooko,項目名稱:tahoe-lafs,代碼行數:55,代碼來源:test_helper.py

示例7: _decrypt_segment

# 需要導入模塊: from pycryptopp.cipher.aes import AES [as 別名]
# 或者: from pycryptopp.cipher.aes.AES import process [as 別名]
 def _decrypt_segment(self, segment_and_salt):
     """
     I take a single segment and its salt, and decrypt it. I return
     the plaintext of the segment that is in my argument.
     """
     segment, salt = segment_and_salt
     self._set_current_status("decrypting")
     self.log("decrypting segment %d" % self._current_segment)
     started = time.time()
     key = hashutil.ssk_readkey_data_hash(salt, self._node.get_readkey())
     decryptor = AES(key)
     plaintext = decryptor.process(segment)
     self._status.accumulate_decrypt_time(time.time() - started)
     return plaintext
開發者ID:jsgf,項目名稱:tahoe-lafs,代碼行數:16,代碼來源:retrieve.py

示例8: _encrypt_and_encode

# 需要導入模塊: from pycryptopp.cipher.aes import AES [as 別名]
# 或者: from pycryptopp.cipher.aes.AES import process [as 別名]
    def _encrypt_and_encode(self):
        # this returns a Deferred that fires with a list of (sharedata,
        # sharenum) tuples. TODO: cache the ciphertext, only produce the
        # shares that we care about.
        self.log("_encrypt_and_encode")

        self._status.set_status("Encrypting")
        started = time.time()

        key = hashutil.ssk_readkey_data_hash(self.salt, self.readkey)
        enc = AES(key)
        crypttext = enc.process(self.newdata)
        assert len(crypttext) == len(self.newdata)

        now = time.time()
        self._status.timings["encrypt"] = now - started
        started = now

        # now apply FEC

        self._status.set_status("Encoding")
        fec = codec.CRSEncoder()
        fec.set_params(self.segment_size,
                       self.required_shares, self.total_shares)
        piece_size = fec.get_block_size()
        crypttext_pieces = [None] * self.required_shares
        for i in range(len(crypttext_pieces)):
            offset = i * piece_size
            piece = crypttext[offset:offset+piece_size]
            piece = piece + "\x00"*(piece_size - len(piece)) # padding
            crypttext_pieces[i] = piece
            assert len(piece) == piece_size

        d = fec.encode(crypttext_pieces)
        def _done_encoding(res):
            elapsed = time.time() - started
            self._status.timings["encode"] = elapsed
            return res
        d.addCallback(_done_encoding)
        return d
開發者ID:ducki2p,項目名稱:tahoe-lafs,代碼行數:42,代碼來源:publish.py

示例9: aes

# 需要導入模塊: from pycryptopp.cipher.aes import AES [as 別名]
# 或者: from pycryptopp.cipher.aes.AES import process [as 別名]
def aes(key, data, counter=False):
    """ encrypt data with aes, using either pycryptopp or PyCrypto.
        Args
            key: The encryption key
            data: plain text data
            counter: a callable, usually not needed
    """
    # using either pycryptopp...
    if hasattr(AES, "process"):
        a = AES(key)
        return a.process(data)
    # ... or PyCrypto
    counter = counter or Counter()
    a = AES.new(key, AES.MODE_CTR, counter=counter)
    rest = len(data) % 16
    if not rest:
        return a.encrypt(data)
    # Data length must be a multiple of 16
    # Pad with bytes all of the same value as the number of padding bytes
    pad = (16 - rest)
    data += chr(pad) * pad
    return a.encrypt(data)[:-pad]
開發者ID:HITGmbH,項目名稱:py-convergent-encryption,代碼行數:24,代碼來源:crypto.py

示例10: _decrypt_privkey

# 需要導入模塊: from pycryptopp.cipher.aes import AES [as 別名]
# 或者: from pycryptopp.cipher.aes.AES import process [as 別名]
 def _decrypt_privkey(self, enc_privkey):
     enc = AES(self._writekey)
     privkey = enc.process(enc_privkey)
     return privkey
開發者ID:drewp,項目名稱:tahoe-lafs,代碼行數:6,代碼來源:filenode.py

示例11: _encrypt_privkey

# 需要導入模塊: from pycryptopp.cipher.aes import AES [as 別名]
# 或者: from pycryptopp.cipher.aes.AES import process [as 別名]
 def _encrypt_privkey(self, writekey, privkey):
     enc = AES(writekey)
     crypttext = enc.process(privkey)
     return crypttext
開發者ID:drewp,項目名稱:tahoe-lafs,代碼行數:6,代碼來源:filenode.py


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