我有一段使用RestTemplate调用REST api的代码。在我的本地系统中,一切都运行得很好。但在其他环境中部署后,第一次尝试时代码就无法工作。它给出的是 org.springframework.web.client.HttpServerErrorException$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)
你能不能给我点线索,为什么会出现这种奇怪的情况?我无法从日志中找出答案。我无法从日志中找出答案,谢谢。
你能不能在服务端也看到任何错误,或者它只是客户端.你提供的代码快照似乎很好。