問題
RestTemplateを介して他のAPIを呼び出す必要がありますが、レスポンスに401エラーが発生した場合に追加の設定がない限り、次のように戻ります。
...
org.springframework.web.client.HttpClientErrorException$Unauthorized: 401 : [no body]
...
問題は401エラーの中にno bodyでデータがないことです。
実際に通信ログ確認をすると、 response bodyにエラーコードとエラーメッセージを送るにもかかわらず、RestTemplate 使用時に 401 エラーが発生すると何も受け取れないのです。そのため、エラー内容の詳細が分からず、非常に不便です。
解決策
解決策として、 HttpComponentsClientHttpRequestFactory を実装して restTemplate に設定すればよいです。
設定する方法は次のとおりです。
...
RestTemplate restTemplate = new RestTemplate();
restTemplate.setRequestFactory(new HttpComponentsClientHttpRequestFactory());
...
設定前と後を比較すると次のようになります。
設定前
responseBodyは空です。
data:image/s3,"s3://crabby-images/cd5c9/cd5c9a0680eefcf5842b7452e201cf83e8fbe805" alt=""
設定後
responseBodyの内容を取れました。
data:image/s3,"s3://crabby-images/70a48/70a486ba9186f811fc77a5db1945a188c46a4824" alt=""
data:image/s3,"s3://crabby-images/17ec5/17ec5d53d6d8126715fad30a75dd75fdbfefdee9" alt=""
少し深掘り
RestTemplate実際の通信はClientHttpRequestFactoryに任せます。デフォルトでは、SimpleClientHttpRequestFactoryを使ってコンストラクタし、java.netのAPIを利用してリクエストを投げます。401レスポンスする際、bodyを取得できないのはjava.netの問題ですね。
コメント