Bonjoue à tous,

J'ai le code python suivant :

main.py :

Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
@APP.route('/auth', methods=['POST'])
def auth():
    """
    Create JWT token based on email.
    """
    request_data = request.get_json()
    if request_data is None:
        print("request returned None")
    else:
        print("doing somethings")
    email = request_data.get('email')
    password = request_data.get('password')
    if not email:
        LOG.error("No email provided")
        return jsonify({"message": "Missing parameter: email"}, 400)
    if not password:
        LOG.error("No password provided")
        return jsonify({"message": "Missing parameter: password"}, 400)
    body = {'email': email, 'password': password}
 
    user_data = body
    print('user_data : ',user_data)
    #return jsonify(token=_get_jwt(user_data).decode('utf-8'))
    return jsonify(token=_get_jwt(user_data))
 
 
@APP.route('/contents', methods=['GET'])
def decode_jwt():
    """
    Check user token and return non-secret data
    """
    if not 'Authorization' in request.headers:
        abort(401)
    data = request.headers['Authorization']
    token = str.replace(str(data), 'Bearer ', '')
    try:
        data = jwt.decode(token, JWT_SECRET, algorithms=['HS256'])
    except: # pylint: disable=bare-except
        abort(401)
    response = {'email': data['email'],
                'exp': data['exp'],
                'nbf': data['nbf'] }
    return jsonify(**response)
 
 
def _get_jwt(user_data):
    exp_time = datetime.datetime.utcnow() + datetime.timedelta(weeks=2)
    payload = {'exp': exp_time,
               'nbf': datetime.datetime.utcnow(),
               'email': user_data['email']}
    return jwt.encode(payload, JWT_SECRET, algorithm='HS256')
 
 
if __name__ == '__main__':
    APP.run(host='127.0.0.1', port=8080, debug=True)
exécuté sous un conteneur docker.

L'image docker est créée avec :

Code : Sélectionner tout - Visualiser dans une fenêtre à part
docker build --tag jwt-api-test .
et exécutée avec :

Code : Sélectionner tout - Visualiser dans une fenêtre à part
80:8080 --env-file=.env_file jwt-api-test


.env_file:

Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
JWT_SECRET='myjwtsecret'
LOG_LEVEL=DEBUG
Et dans la fenêtre du terminal, ou il a été exécuté le conteneur Docker, je peux lire:

Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
  File "/app/main.py", line 84, in auth    email = request_data.get('email')
AttributeError: 'NoneType' object has no attribute 'get'
Et quand je teste dans un deuxième terminal, la commande Curl suivante:

Code : Sélectionner tout - Visualiser dans une fenêtre à part
export TOKEN=`curl --data '{"email":"test@test.com","password":"pass"}' --header "Content-Type: application/json" -X POST localhost:80/auth  | jq -r '.token'`
je reçois l'erreur :



ou parfois :

Code : Sélectionner tout - Visualiser dans une fenêtre à part
parse error: Invalid numeric literal at line 1, column 10
je crois que request_data est toujours à none, pourtant les paramètres sont bien passés dans le test curl ?

Merci de votre aide.