0

私はAWS LambdaのためにPythonを使っています。 Profile PATCHとProfile DELETE APIコールがあります。 PATCHリクエストは正常に動作します。 DELETEは、InternalServerErrorを返します。ast.literal_eval InternalServerError

profile_request = ast.literal_eval(str(event['_body'])) 

PATCHは全く同じものを使用します。私はさらに、PATCHの行をコピーして貼り付けてみたところ、タイプミスがないことを確認しました。私は人々が構文の問題がこれを引き起こす可能性があると言うのを見ました。私は本文をPATCHからコピーして貼り付け、profileをarchive_statusに置き換えて構文の問題がないことを確認しました。イベントは辞書です。イベント['_ body']はユニコードタイプです。両方の要求は、AuthorizationとHeadersの要件がまったく同じです。私はCloudWatchのログをチェックして、ボディが実際に_bodyとしてイベントにリストされていることを確認しました。 InternalServerErrorがDELETEプロファイル用であり、PATCHプロファイル用ではない理由がわかりません。任意の提案をいただければ幸いです。

PATCH本体:

{ 

    "AccessToken": "eyJraWQiOiIzRUZtNG1lRE45c1wvQU9XUGdiYkZJNm1wakVkOVRFR05PYTY0SXJZOWRDdz0iLCJhbGciOiJSUzI1NiJ9.eyJzdWIiOiIwZTQ1ZDYyZi1mYzQxLTQxNTQtYjZiOC04NjBiNTdkZWNkOGUiLCJkZXZpY2Vfa2V5IjoidXMtZWFzdC0xXzhkYTA3NWQ2LWEzNmItNDZhNS04YjAyLWY3ZmNjY2UxMGZiOCIsInRva2VuX3VzZSI6ImFjY2VzcyIsInNjb3BlIjoiYXdzLmNvZ25pdG8uc2lnbmluLnVzZXIuYWRtaW4iLCJpc3MiOiJodHRwczpcL1wvY29nbml0by1pZHAudXMtZWFzdC0xLmFtYXpvbmF3cy5jb21cL3VzLWVhc3QtMV96dnNGSkYzRzEiLCJleHAiOjE1MDYzNzI2MjksImlhdCI6MTUwNjM2OTAyOSwianRpIjoiMDU3NTkwMzItYmQ5YS00MzljLWJjM2QtYWY2OGZiZjJmNTBiIiwiY2xpZW50X2lkIjoiNWNscm9vNDhtamZpb2QzaDRoZGgyZDNvZHUiLCJ1c2VybmFtZSI6IjBlNDVkNjJmLWZjNDEtNDE1NC1iNmI4LTg2MGI1N2RlY2Q4ZSJ9.G2-gGYyZajrsAikFPuuttYQAj1Yc7uj-UUz469NEUk0SoEFvcJ3E6MOINmIWYg1W6BwJG09W4C_DvBrbybNZep-TtVoAHqNeuiEubt4IABeycZ9ELhKS4G-aaIvbV6CTVFVljFcUdTqCBf0TP7kxKp6P2kRRx08PjCqfQX-34XE-YJt2FyIGzSc958OT0MasROdHxr_ozJS6LGHw52BF1UG1llpR3YPGtMe8Gz9Y65RFEIDIpXllShKSFogvy-rdJFnaJqAYYn6WfjtmqDUjYzFTNZmGNOWy7_BxGFX90lUBB0V47k8M4nxvC_qWQ9o1LTkCYXIDD9sWMCtY4ewYmw", 
    "profile": { 
     "name": "Test" 
    } 
} 

DELETE体:

{ 

    "AccessToken": "eyJraWQiOiIzRUZtNG1lRE45c1wvQU9XUGdiYkZJNm1wakVkOVRFR05PYTY0SXJZOWRDdz0iLCJhbGciOiJSUzI1NiJ9.eyJzdWIiOiIwZTQ1ZDYyZi1mYzQxLTQxNTQtYjZiOC04NjBiNTdkZWNkOGUiLCJkZXZpY2Vfa2V5IjoidXMtZWFzdC0xXzhkYTA3NWQ2LWEzNmItNDZhNS04YjAyLWY3ZmNjY2UxMGZiOCIsInRva2VuX3VzZSI6ImFjY2VzcyIsInNjb3BlIjoiYXdzLmNvZ25pdG8uc2lnbmluLnVzZXIuYWRtaW4iLCJpc3MiOiJodHRwczpcL1wvY29nbml0by1pZHAudXMtZWFzdC0xLmFtYXpvbmF3cy5jb21cL3VzLWVhc3QtMV96dnNGSkYzRzEiLCJleHAiOjE1MDYzNzI2MjksImlhdCI6MTUwNjM2OTAyOSwianRpIjoiMDU3NTkwMzItYmQ5YS00MzljLWJjM2QtYWY2OGZiZjJmNTBiIiwiY2xpZW50X2lkIjoiNWNscm9vNDhtamZpb2QzaDRoZGgyZDNvZHUiLCJ1c2VybmFtZSI6IjBlNDVkNjJmLWZjNDEtNDE1NC1iNmI4LTg2MGI1N2RlY2Q4ZSJ9.G2-gGYyZajrsAikFPuuttYQAj1Yc7uj-UUz469NEUk0SoEFvcJ3E6MOINmIWYg1W6BwJG09W4C_DvBrbybNZep-TtVoAHqNeuiEubt4IABeycZ9ELhKS4G-aaIvbV6CTVFVljFcUdTqCBf0TP7kxKp6P2kRRx08PjCqfQX-34XE-YJt2FyIGzSc958OT0MasROdHxr_ozJS6LGHw52BF1UG1llpR3YPGtMe8Gz9Y65RFEIDIpXllShKSFogvy-rdJFnaJqAYYn6WfjtmqDUjYzFTNZmGNOWy7_BxGFX90lUBB0V47k8M4nxvC_qWQ9o1LTkCYXIDD9sWMCtY4ewYmw", 
    "archive_status": "archive" 
} 
+2

APIペイロードは、両方ともJSONであるように見えます。 'json'モジュールの代わりに' ast.literal_eval'を使って解析する理由はありますか? – jwodder

+1

実際のエラーとスタックトレースは何ですか? – Ryan

答えて

0

申し訳ありません。私はかなり新しいpythonとjsonとAWSの新しいブランドです。デプロイメントのための別の会社のセットアップの聖火といくつかの基本的なコードを持つapiのスケルトン。私はそれをすべて理解し、私の会社が望んでいるようにそれを働かせる方法を学ぶはずです。私は郵便配達員を通じてテストしていました。クラウドウォッチに行くラムダコードロガーは、どのように私が問題を追跡していたのです。

profile_request = ast.literal_eval(STR(イベント[ '_ボディ']))

logger.info(profile_request)

I:それは問題がast.literal_eval直後にログ行をした判明しますクラウドウォッチのログが見えないと仮定した場合、ast.literal_evalが問題となりました。ローカルでテストする方法を見つけることで、ログラインがAttributeErrorを引き起こしていることがわかりました。 'dict'オブジェクトに属性 'strip'がありません。これは簡単なことで、問題は解決されます。私はローカルで今もテストする方法を知ってうれしい。すぐに返信いただきありがとうございます。