2 つの異なるソフトウェア環境 ( Environment AとEnvironment B ) があり、両方の環境で PyJWT を実行しようとしています。1 つの環境Environment Aでは完全に正常に動作していますが、 Environment Bでは失敗します。
==で呼び出したときに環境 Bで発生するエラーは次のとおりです。jwt.encode()
algorithm
ES
Algorithm not supported
Environment Aでは機能するのにEnvironment Bでは機能しない理由を理解しようとしています。2 つの環境に異なるバージョンの PyJWT がインストールされているようです。しかし、環境 Bにインストールされている PyJWT のバージョンを特定することは、私には難しいことがわかりました。どうすればできますか??
Environment AとEnvironment Bの両方で、次のインストルメント化されたコードを実行しました。
import jwt, cryptography, sys, pkg_resources
my_private_key = """XXXXX"""
my_public_key = """YYYYYY"""
original = {"Hello": "World"}
print "sys.version = {}".format(str(sys.version))
try:
print "dir(jwt) = {}".format(str(dir(jwt)))
except Exception as e:
print "Failed to get dir of jwt module: {}".format(e)
try:
print "dir(cryptography) = {}".format(str(dir(cryptography)))
except Exception as e:
print "Failed to get dir of cryptography module: {}".format(e)
try:
print "jwt = {}".format(str(jwt.__version__))
except Exception as e:
print "Failed to get version of jwt module using .__version: {}".format(e)
try:
print "cryptography = {}".format(str(cryptography.__version__))
except Exception as e:
print "Failed to get version of cryptography module using .__version: {}".format(e)
try:
print "pkg_resources.require('jwt')[0].version = {}".format(str(pkg_resources.require("jwt")[0].version))
except Exception as e:
print "Failed to get version of jwt module via pkg_resources: {}".format(e)
try:
print "pkg_resources.require('cryptography')[0].version = {}".format(str(pkg_resources.require("cryptography")[0].version))
except Exception as e:
print "Failed to get version of cryptography module via pkg_resources: {}".format(e)
try:
print "original = {}".format(str(original))
encoded = jwt.encode(original, my_private_key, algorithm='ES256')
except Exception as e:
print "encoding exception = {}".format(str(e))
else:
try:
print "encoded = {}".format(str(encoded))
unencoded = jwt.decode(encoded, my_public_key, algorithms=['ES256'])
except Exception as e:
print "decoding exception = {}".format(str(e))
else:
print "unencoded = {}".format(str(unencoded))
環境Aでは、エンコードは成功します。
sys.version = 2.7.12 (default, Sep 1 2016, 22:14:00)
[GCC 4.8.3 20140911 (Red Hat 4.8.3-9)]
dir(jwt) = ['DecodeError', 'ExpiredSignature', 'ExpiredSignatureError', 'ImmatureSignatureError', 'InvalidAudience', 'InvalidAudienceError', 'InvalidIssuedAtError', 'InvalidIssuer', 'InvalidIssuerError', 'InvalidTokenError', 'MissingRequiredClaimError', 'PyJWS', 'PyJWT', '__author__', '__builtins__', '__copyright__', '__doc__', '__file__', '__license__', '__name__', '__package__', '__path__', '__title__', '__version__', 'algorithms', 'api_jws', 'api_jwt', 'compat', 'decode', 'encode', 'exceptions', 'get_unverified_header', 'register_algorithm', 'unregister_algorithm', 'utils']
dir(cryptography) = ['__about__', '__all__', '__author__', '__builtins__', '__copyright__', '__doc__', '__email__', '__file__', '__license__', '__name__', '__package__', '__path__', '__summary__', '__title__', '__uri__', '__version__', 'absolute_import', 'division', 'exceptions', 'hazmat', 'print_function', 'sys', 'utils', 'warnings']
jwt = 1.4.2
cryptography = 1.5.2
Failed to get version of jwt module via pkg_resources: jwt
pkg_resources.require('cryptography')[0].version = 1.5.2
original = {'Hello': 'World'}
encoded = eyJhbGciOiJFUzI1NiIsInR5cCI6IkpXVCJ9.eyJIZWxsbyI6IldvcmxkIn0.ciaXCcO2gTqsQ4JUEKj5q4YX6vfHu33XY32g2MNIVEDXHNllpuqDCj-cCrlGPf6hGNifAJbNI9kBaAyuCIwyJQ
unencoded = {u'Hello': u'World'}
環境 Bでは、エンコーディングが失敗します。実行中の PyJWT のバージョンがわからないことがわかります。ES256
ただし、このバージョンの PyJWT には、使用しようとしているアルゴリズムがありません。
sys.version = 2.7.12 (default, Sep 1 2016, 22:14:00)
[GCC 4.8.3 20140911 (Red Hat 4.8.3-9)]"
dir(jwt) = ['DecodeError', 'ExpiredSignature', 'Mapping', 'PKCS1_v1_5', 'SHA256', 'SHA384', 'SHA512', '__all__', '__builtins__', '__doc__', '__file__', '__name__', '__package__', '__path__', 'base64', 'base64url_decode', 'base64url_encode', 'binascii', 'constant_time_compare', 'datetime', 'decode', 'encode', 'hashlib', 'header', 'hmac', 'json', 'load', 'signing_methods', 'sys', 'timegm', 'unicode_literals', 'verify_methods', 'verify_signature']
dir(cryptography) = ['__about__', '__all__', '__author__', '__builtins__', '__copyright__', '__doc__', '__email__', '__file__', '__license__', '__name__', '__package__', '__path__', '__summary__', '__title__', '__uri__', '__version__', 'absolute_import', 'division', 'print_function', 'sys', 'warnings']
Failed to get version of jwt module using .__version: 'module' object has no attribute '__version__'
cryptography = 1.5.2
Failed to get version of jwt module via pkg_resources: jwt
pkg_resources.require('cryptography')[0].version = 1.5.2
original = {'Hello': 'World'}
encoding exception = Algorithm not supported