将 Azure JWK 对象转换为 jwcrypto JWK 对象的简单方法如下所示。
import jwcrypto.jwk as jwk
azureJwkObj = .... # your Azure JWK object
azureJwkDict = azureJwkObj.__dict__
jwcryptoJwkObject = jwk.JWK(**azureJwkDict)
下面也一样。
jwcryptoJwkObject = jwk.JWK().import_key(**azureJwkDict)
在我查看了 Azure KeyVault SDK 的源代码和 Python 的 jwcrypto 的源代码后,我认为 jwcrypto.jwk.JWK 的函数 import_key 需要 dict 作为参数来生成 jwcrypto JWK 对象.
根据Azure KeyVault SDK的源代码json_web_key_py3.py和jwcrypto的jwk.py,我尝试生成一个jwcrypto的JWK对象,通过下面的代码查看其结构。
from jwcrypto import jwk
key = jwk.JWK.generate(kty='oct', size=256)
print(key.__dict__)
# The output is {'_params': {'kty': 'oct'}, '_key': {'k': 'HJUk1CeudZ2Tur0fzHnOi-1U9UjxaUjClRW8TvqFakI'}, '_unknown': {}}
然后,我尝试使用下面的代码将 Azure JWK 对象转换为 jwcrypto.jwk.JWK.import_key 所需的字典,以通过 import_key 函数创建 jwcrypto JWK 对象。
import jwcrypto.jwk as jwk
azureJwkObj = .... # your Azure JWK object
azureJwkDict = azureJwkObj.__dict__
_params = {k: v for k, v in azureJwkDict.items() if k in jwk.JWKParamsRegistry.keys()}
kty = _params.get('kty', None)
_key = {k: v for k, v in azureJwkDict.items() if k in jwk.JWKValuesRegistry[kty].keys()}
args = {'_params': _params, '_key': _key, '_unknown': {}}
jwcryptoJwkObject = jwk.JWK.import_key(args)