本文整理匯總了Python中cryptography.hazmat.primitives.cmac.CMAC.update方法的典型用法代碼示例。如果您正苦於以下問題:Python CMAC.update方法的具體用法?Python CMAC.update怎麽用?Python CMAC.update使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類cryptography.hazmat.primitives.cmac.CMAC
的用法示例。
在下文中一共展示了CMAC.update方法的9個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: test_invalid_verify
# 需要導入模塊: from cryptography.hazmat.primitives.cmac import CMAC [as 別名]
# 或者: from cryptography.hazmat.primitives.cmac.CMAC import update [as 別名]
def test_invalid_verify(self, backend):
key = b"2b7e151628aed2a6abf7158809cf4f3c"
cmac = CMAC(AES(key), backend)
cmac.update(b"6bc1bee22e409f96e93d7e117393172a")
with pytest.raises(InvalidSignature):
cmac.verify(b"foobar")
示例2: test_aes_verify
# 需要導入模塊: from cryptography.hazmat.primitives.cmac import CMAC [as 別名]
# 或者: from cryptography.hazmat.primitives.cmac.CMAC import update [as 別名]
def test_aes_verify(self, backend, params):
key = params["key"]
message = params["message"]
output = params["output"]
cmac = CMAC(AES(binascii.unhexlify(key)), backend)
cmac.update(binascii.unhexlify(message))
assert cmac.verify(binascii.unhexlify(output)) is None
示例3: test_aes_generate
# 需要導入模塊: from cryptography.hazmat.primitives.cmac import CMAC [as 別名]
# 或者: from cryptography.hazmat.primitives.cmac.CMAC import update [as 別名]
def test_aes_generate(self, backend, params):
key = params["key"]
message = params["message"]
output = params["output"]
cmac = CMAC(AES(binascii.unhexlify(key)), backend)
cmac.update(binascii.unhexlify(message))
assert binascii.hexlify(cmac.finalize()) == output
示例4: test_verify_reject_unicode
# 需要導入模塊: from cryptography.hazmat.primitives.cmac import CMAC [as 別名]
# 或者: from cryptography.hazmat.primitives.cmac.CMAC import update [as 別名]
def test_verify_reject_unicode(self, backend):
key = b"2b7e151628aed2a6abf7158809cf4f3c"
cmac = CMAC(AES(key), backend)
with pytest.raises(TypeError):
cmac.update(six.u(''))
with pytest.raises(TypeError):
cmac.verify(six.u(''))
示例5: test_3des_generate
# 需要導入模塊: from cryptography.hazmat.primitives.cmac import CMAC [as 別名]
# 或者: from cryptography.hazmat.primitives.cmac.CMAC import update [as 別名]
def test_3des_generate(self, backend, params):
key1 = params["key1"]
key2 = params["key2"]
key3 = params["key3"]
key = key1 + key2 + key3
message = params["message"]
output = params["output"]
cmac = CMAC(TripleDES(binascii.unhexlify(key)), backend)
cmac.update(binascii.unhexlify(message))
assert binascii.hexlify(cmac.finalize()) == output
示例6: test_3des_verify
# 需要導入模塊: from cryptography.hazmat.primitives.cmac import CMAC [as 別名]
# 或者: from cryptography.hazmat.primitives.cmac.CMAC import update [as 別名]
def test_3des_verify(self, backend, params):
key1 = params["key1"]
key2 = params["key2"]
key3 = params["key3"]
key = key1 + key2 + key3
message = params["message"]
output = params["output"]
cmac = CMAC(TripleDES(binascii.unhexlify(key)), backend)
cmac.update(binascii.unhexlify(message))
assert cmac.verify(binascii.unhexlify(output)) is None
示例7: test_raises_after_finalize
# 需要導入模塊: from cryptography.hazmat.primitives.cmac import CMAC [as 別名]
# 或者: from cryptography.hazmat.primitives.cmac.CMAC import update [as 別名]
def test_raises_after_finalize(self, backend):
key = b"2b7e151628aed2a6abf7158809cf4f3c"
cmac = CMAC(AES(key), backend)
cmac.finalize()
with pytest.raises(AlreadyFinalized):
cmac.update(b"foo")
with pytest.raises(AlreadyFinalized):
cmac.copy()
with pytest.raises(AlreadyFinalized):
cmac.finalize()
示例8: test_aes_cmac
# 需要導入模塊: from cryptography.hazmat.primitives.cmac import CMAC [as 別名]
# 或者: from cryptography.hazmat.primitives.cmac.CMAC import update [as 別名]
def test_aes_cmac(backend, wycheproof):
key = binascii.unhexlify(wycheproof.testcase["key"])
msg = binascii.unhexlify(wycheproof.testcase["msg"])
tag = binascii.unhexlify(wycheproof.testcase["tag"])
# skip truncated tags, which we don't support in the API
if wycheproof.valid and len(tag) == 16:
ctx = CMAC(AES(key), backend)
ctx.update(msg)
ctx.verify(tag)
elif len(key) not in [16, 24, 32]:
with pytest.raises(ValueError):
CMAC(AES(key), backend)
else:
ctx = CMAC(AES(key), backend)
ctx.update(msg)
with pytest.raises(InvalidSignature):
ctx.verify(tag)
示例9: test_copy_with_backend
# 需要導入模塊: from cryptography.hazmat.primitives.cmac import CMAC [as 別名]
# 或者: from cryptography.hazmat.primitives.cmac.CMAC import update [as 別名]
def test_copy_with_backend(self, backend):
key = b"2b7e151628aed2a6abf7158809cf4f3c"
cmac = CMAC(AES(key), backend)
cmac.update(b"6bc1bee22e409f96e93d7e117393172a")
copy_cmac = cmac.copy()
assert cmac.finalize() == copy_cmac.finalize()