restTemplate postForEntity иногда приводит к ошибке 400 - PullRequest
0 голосов
/ 09 января 2019

В моем приложении для Android я пытаюсь сделать POST с помощью restTemplate.postForEntity (), но в первый раз, когда я пытаюсь опубликовать данные, я получаю сообщение об ошибке 400. После того, как мой синхронизирующий метод timetrigger попытается опубликовать данные снова, он работает, и я получаю 200. Я не думаю, что это проблема с бэкендом, потому что я сделал пару запросов через Swagger и Postman на одном интерфейсе, и все они работали без проблема.

Это ошибка, которую я получаю:

POST request for "<url>" resulted in 400 (); invoking error handler org.springframework.web.client.HttpClientErrorException: 400

Это то, что я вижу в postForEntity () при отладке: 'java.lang.NullPointerException' Cannot evaluate org.springframework.http.ResponseEntity.toString()

Это код:

public ResponseEntity<ArrayList> postServiceData(List<BasicService> attributes) {
    HttpStatus status = null;
 ResponseEntity<ArrayList> chargerServiceResponse = new ResponseEntity<ArrayList>(status);
    try {
        RestTemplate restTemplate = new RestTemplate();
        restTemplate.getMessageConverters().add(new MappingJackson2HttpMessageConverter());
        HttpEntity<?> entity = RestServiceUtils.getHttpEntity(attributes, context);
        chargerServiceResponse = restTemplate.postForEntity(url, entity, ArrayList.class);
        SynchronisationStorage synchronisationStorage = new SynchronisationStorage(context);
        synchronisationStorage.updateLastSynchronisationDate();
        loggingStorageDbHelper.logSuccess(R.string.logging_save_send_charger_service_to_backend, 1000);
    } catch (HttpClientErrorException e) {
      /* do stuff*/
    }
}

Чтобы установить тело и токен:

@NonNull
public static HttpEntity<?> getHttpEntity(List attributes, Context context) {
    HttpHeaders headers = new HttpHeaders();
    try {
        headers.set(ServiceAppConstants.HEADER_ACCEPT, ServiceAppConstants.MEDIATYPE_JSON);
        UserStorage userStorage = new UserStorage(context);
        String token = userStorage.getJsonWebToken();
        headers.set(ServiceAppConstants.HEADER_SECURITY_TOKEN, token);
    }catch (Exception ex){
        Log.e(RestServiceUtils.class.getName(), "Exception ocurred while trying to set token to header", ex);
    }
    return new HttpEntity<Object>(attributes, headers);
}
...