我有一段使用RestTemplate调用REST api的代码。 我的本地系统一切正常。 但是在其他环境中部署后,代码在第一次尝试中无法工作。 它提供org.springframework.web.client.HttpServerRoreXception$InternalServerError
。 但是,如果我再次调用这个方法,它会起作用。 我不知道为什么这表现得很奇怪。 在我的情况下,每一次平均的尝试都是有效的。 下面是我的代码块:
final String url = this.environment.getProperty("app.base-uri") + "/testEmail/";
final HttpHeaders httpHeaders = new HttpHeaders();
httpHeaders.setContentType(MediaType.APPLICATION_JSON);
httpHeaders.set(Constants.AUTHORIZATION, this.getRequestAuthorizationHeader());
final HttpEntity<EmailRequestModel> httpEntity = new HttpEntity<>(emailRequestModel, httpHeaders);
final ResponseEntity<String> emailResponseEntity = new RestTemplate().postForEntity(url, httpEntity, String.class);
以下是日志:
org.springframework.web.client.HttpServerErrorException$InternalServerError:
at org.springframework.web.client.HttpServerErrorException.create (HttpServerErrorException.java100)
at org.springframework.web.client.DefaultResponseErrorHandler.handleError (DefaultResponseErrorHandler.java172)
at org.springframework.web.client.DefaultResponseErrorHandler.handleError (DefaultResponseErrorHandler.java112)
at org.springframework.web.client.ResponseErrorHandler.handleError (ResponseErrorHandler.java63)
at org.springframework.web.client.RestTemplate.handleResponse (RestTemplate.java785)
at org.springframework.web.client.RestTemplate.doExecute (RestTemplate.java743)
at org.springframework.web.client.RestTemplate.execute (RestTemplate.java677)
at org.springframework.web.client.RestTemplate.postForEntity (RestTemplate.java452)
at com.toyota.tmi.service.impl.ExtraRequestServiceImpl.sendWorkflowEmail (ExtraRequestServiceImpl.java1153)
你能给我任何线索为什么这表现得很奇怪吗。 我无法从日志中找到答案。 谢了。
你能在服务端看到任何错误吗?或者它只是客户端。 您提供的代码快照似乎很好。