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


Python SimonCipher.decrypt方法代碼示例

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


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

示例1: test_simon128_256

# 需要導入模塊: from simon import SimonCipher [as 別名]
# 或者: from simon.SimonCipher import decrypt [as 別名]
 def test_simon128_256(self):
     block_size = 128
     key_size = 256
     for x in range(self.test_cnt):
         key = randint(0, (2**key_size) - 1)
         plaintxt = randint(0, (2**block_size) - 1)
         c = SimonCipher(key, key_size, block_size, 'ECB')
         assert c.decrypt(c.encrypt(plaintxt)) == plaintxt, 'Test %r Failed with Random Key %r and Random Plaintext %r' % (x, hex(key), hex(plaintxt))
開發者ID:prashantbarca,項目名稱:simon-speck-sim,代碼行數:10,代碼來源:tests.py

示例2: test_ofb_mode_chain

# 需要導入模塊: from simon import SimonCipher [as 別名]
# 或者: from simon.SimonCipher import decrypt [as 別名]
    def test_ofb_mode_chain(self):
        plaintxts = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]

        c = SimonCipher(self.key, self.key_size, self.block_size, 'OFB', init=self.iv)
        ciphertexts = [c.encrypt(x) for x in plaintxts]
        c = SimonCipher(self.key, self.key_size, self.block_size, 'OFB', init=self.iv)
        decryptexts = [c.decrypt(x) for x in ciphertexts]

        assert plaintxts == decryptexts
開發者ID:yuehann,項目名稱:IOT_Gateway,代碼行數:11,代碼來源:tests.py

示例3: test_simon128_256

# 需要導入模塊: from simon import SimonCipher [as 別名]
# 或者: from simon.SimonCipher import decrypt [as 別名]
 def test_simon128_256(self):
     key = 0x1f1e1d1c1b1a191817161514131211100f0e0d0c0b0a09080706050403020100
     plaintxt = 0x74206e69206d6f6f6d69732061207369
     ciphertxt = 0x8d2b5579afc8a3a03bf72a87efe7b868
     block_size = 128
     key_size = 256
     c = SimonCipher(key, key_size, block_size, 'ECB')
     assert c.encrypt(plaintxt) == ciphertxt
     assert c.decrypt(ciphertxt) == plaintxt
開發者ID:yuehann,項目名稱:IOT_Gateway,代碼行數:11,代碼來源:tests.py

示例4: test_simon128_192

# 需要導入模塊: from simon import SimonCipher [as 別名]
# 或者: from simon.SimonCipher import decrypt [as 別名]
 def test_simon128_192(self):
     key = 0x17161514131211100f0e0d0c0b0a09080706050403020100
     plaintxt = 0x206572656874206e6568772065626972
     ciphertxt = 0xc4ac61effcdc0d4f6c9c8d6e2597b85b
     block_size = 128
     key_size = 192
     c = SimonCipher(key, key_size, block_size, 'ECB')
     assert c.encrypt(plaintxt) == ciphertxt
     assert c.decrypt(ciphertxt) == plaintxt
開發者ID:yuehann,項目名稱:IOT_Gateway,代碼行數:11,代碼來源:tests.py

示例5: test_simon128_128

# 需要導入模塊: from simon import SimonCipher [as 別名]
# 或者: from simon.SimonCipher import decrypt [as 別名]
 def test_simon128_128(self):
     key = 0x0f0e0d0c0b0a09080706050403020100
     plaintxt = 0x63736564207372656c6c657661727420
     ciphertxt = 0x49681b1e1e54fe3f65aa832af84e0bbc
     block_size = 128
     key_size = 128
     c = SimonCipher(key, key_size, block_size, 'ECB')
     assert c.encrypt(plaintxt) == ciphertxt
     assert c.decrypt(ciphertxt) == plaintxt
開發者ID:yuehann,項目名稱:IOT_Gateway,代碼行數:11,代碼來源:tests.py

示例6: test_simon96_144

# 需要導入模塊: from simon import SimonCipher [as 別名]
# 或者: from simon.SimonCipher import decrypt [as 別名]
 def test_simon96_144(self):
     key = 0x1514131211100d0c0b0a0908050403020100
     plaintxt = 0x74616874207473756420666f
     ciphertxt = 0xecad1c6c451e3f59c5db1ae9
     block_size = 96
     key_size = 144
     c = SimonCipher(key, key_size, block_size, 'ECB')
     assert c.encrypt(plaintxt) == ciphertxt
     assert c.decrypt(ciphertxt) == plaintxt
開發者ID:yuehann,項目名稱:IOT_Gateway,代碼行數:11,代碼來源:tests.py

示例7: test_simon96_96

# 需要導入模塊: from simon import SimonCipher [as 別名]
# 或者: from simon.SimonCipher import decrypt [as 別名]
 def test_simon96_96(self):
     key = 0x0d0c0b0a0908050403020100
     plaintxt = 0x2072616c6c69702065687420
     ciphertxt = 0x602807a462b469063d8ff082
     block_size = 96
     key_size = 96
     c = SimonCipher(key, key_size, block_size, 'ECB')
     assert c.encrypt(plaintxt) == ciphertxt
     assert c.decrypt(ciphertxt) == plaintxt
開發者ID:yuehann,項目名稱:IOT_Gateway,代碼行數:11,代碼來源:tests.py

示例8: test_simon64_128

# 需要導入模塊: from simon import SimonCipher [as 別名]
# 或者: from simon.SimonCipher import decrypt [as 別名]
 def test_simon64_128(self):
     key = 0x1b1a1918131211100b0a090803020100
     plaintxt = 0x656b696c20646e75
     ciphertxt = 0x44c8fc20b9dfa07a
     block_size = 64
     key_size = 128
     c = SimonCipher(key, key_size, block_size, 'ECB')
     assert c.encrypt(plaintxt) == ciphertxt
     assert c.decrypt(ciphertxt) == plaintxt
開發者ID:yuehann,項目名稱:IOT_Gateway,代碼行數:11,代碼來源:tests.py

示例9: test_simon64_96

# 需要導入模塊: from simon import SimonCipher [as 別名]
# 或者: from simon.SimonCipher import decrypt [as 別名]
 def test_simon64_96(self):
     key = 0x131211100b0a090803020100
     plaintxt = 0x6f7220676e696c63
     ciphertxt = 0x5ca2e27f111a8fc8
     block_size = 64
     key_size = 96
     c = SimonCipher(key, key_size, block_size, 'ECB')
     assert c.encrypt(plaintxt) == ciphertxt
     assert c.decrypt(ciphertxt) == plaintxt
開發者ID:yuehann,項目名稱:IOT_Gateway,代碼行數:11,代碼來源:tests.py

示例10: test_simon48_96

# 需要導入模塊: from simon import SimonCipher [as 別名]
# 或者: from simon.SimonCipher import decrypt [as 別名]
 def test_simon48_96(self):
     key = 0x1a19181211100a0908020100
     plaintxt = 0x72696320646e
     ciphertxt = 0x6e06a5acf156
     block_size = 48
     key_size = 96
     c = SimonCipher(key, key_size, block_size, 'ECB')
     assert c.encrypt(plaintxt) == ciphertxt
     assert c.decrypt(ciphertxt) == plaintxt
開發者ID:yuehann,項目名稱:IOT_Gateway,代碼行數:11,代碼來源:tests.py

示例11: test_simon48_72

# 需要導入模塊: from simon import SimonCipher [as 別名]
# 或者: from simon.SimonCipher import decrypt [as 別名]
 def test_simon48_72(self):
     key = 0x1211100a0908020100
     plaintxt = 0x6120676e696c
     ciphertxt = 0xdae5ac292cac
     block_size = 48
     key_size = 72
     c = SimonCipher(key, key_size, block_size, 'ECB')
     assert c.encrypt(plaintxt) == ciphertxt
     assert c.decrypt(ciphertxt) == plaintxt
開發者ID:yuehann,項目名稱:IOT_Gateway,代碼行數:11,代碼來源:tests.py

示例12: test_simon32_64

# 需要導入模塊: from simon import SimonCipher [as 別名]
# 或者: from simon.SimonCipher import decrypt [as 別名]
 def test_simon32_64(self):
     key = 0x1918111009080100
     plaintxt = 0x65656877
     ciphertxt = 0xc69be9bb
     block_size = 32
     key_size = 64
     c = SimonCipher(key, key_size, block_size, 'ECB')
     assert c.encrypt(plaintxt) == ciphertxt
     assert c.decrypt(ciphertxt) == plaintxt
開發者ID:yuehann,項目名稱:IOT_Gateway,代碼行數:11,代碼來源:tests.py

示例13: test_ofb_mode_equivalent

# 需要導入模塊: from simon import SimonCipher [as 別名]
# 或者: from simon.SimonCipher import decrypt [as 別名]
    def test_ofb_mode_equivalent(self):
        c = SimonCipher(self.key, self.key_size, self.block_size, 'OFB', init=self.iv)
        ofb_encrypt = c.encrypt(self.plaintxt)
        c = SimonCipher(self.key, self.key_size, self.block_size, 'OFB', init=self.iv)
        ofb_decrypt = c.decrypt(ofb_encrypt)

        c = SimonCipher(self.key, self.key_size, self.block_size, 'ECB')
        ecb_out = c.encrypt(self.iv)
        ofb_equivalent_encrypt = ecb_out ^ self.plaintxt
        ofb_equivalent_decrypt = ecb_out ^ ofb_equivalent_encrypt

        assert ofb_encrypt == ofb_equivalent_encrypt
        assert ofb_decrypt == ofb_equivalent_decrypt
開發者ID:yuehann,項目名稱:IOT_Gateway,代碼行數:15,代碼來源:tests.py

示例14: test_ctr_mode_single_cycle

# 需要導入模塊: from simon import SimonCipher [as 別名]
# 或者: from simon.SimonCipher import decrypt [as 別名]
    def test_ctr_mode_single_cycle(self):

        self.counter = 0x01

        c = SimonCipher(self.key, self.key_size, self.block_size, 'CTR', init=self.iv, counter=self.counter)
        ctr_out = c.encrypt(self.plaintxt)

        self.counter = 0x01

        c = SimonCipher(self.key, self.key_size, self.block_size, 'CTR', init=self.iv, counter=self.counter)
        output_plaintext = c.decrypt(ctr_out)

        assert output_plaintext == self.plaintxt
開發者ID:yuehann,項目名稱:IOT_Gateway,代碼行數:15,代碼來源:tests.py

示例15: argon2_test

# 需要導入模塊: from simon import SimonCipher [as 別名]
# 或者: from simon.SimonCipher import decrypt [as 別名]
def argon2_test():
    start = time.time()
    ph = PasswordHasher()
    hash = ph.hash(password)
    hashed = hashlib.sha256(hash).digest()
    end = time.time()
    print "argon2 : ",(end-start)
    start = time.time()
    obj =AES.new(hashed,AES.MODE_CBC, 'This is an IV456')
    ciphertext = obj.encrypt("The answer is no")
    end = time.time()
    print "AES Encrypt: ",(end-start)*1000
    start = time.time()
    obj =AES.new(hashed,AES.MODE_CBC, 'This is an IV456')
    plaintext = obj.decrypt(ciphertext)
    end = time.time()
    print "AES Decrypt: ",(end-start)*1000
    my_plaintext = 0xCCCCAAAA55553333
    start = time.time()
    big_cipher = SimonCipher(0x111122223333444455556666777788889999AAAABBBBCCCCDDDDEEEEFFFF0000, key_size=256, block_size=128)
    simon = big_cipher.encrypt(my_plaintext)
    end = time.time()
    print "Simon Encrypt: ",(end-start)*1000
    start = time.time()
    big_cipher1 = SpeckCipher(0x111122223333444455556666777788889999AAAABBBBCCCCDDDDEEEEFFFF0000, key_size=256, block_size=128)
    speck = big_cipher1.encrypt(my_plaintext)
    end = time.time()
    print "Speck Encrypt: ",(end-start)*1000
    start = time.time()
    big_cipher = SimonCipher(0x111122223333444455556666777788889999AAAABBBBCCCCDDDDEEEEFFFF0000, key_size=256, block_size=128)
    plain = big_cipher.decrypt(simon)
    end = time.time()
    print plain
    print "Simon Decrypt: ",(end-start)*1000
    start = time.time()
    big_cipher1 = SpeckCipher(0x111122223333444455556666777788889999AAAABBBBCCCCDDDDEEEEFFFF0000, key_size=256, block_size=128)
    plain = big_cipher1.decrypt(speck)
    end = time.time()
    print plain
    print "Speck Decrypt: ",(end-start)*1000
開發者ID:prashantbarca,項目名稱:simon-speck-sim,代碼行數:42,代碼來源:share.py


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