Почему Retrofit игнорирует код успешного ответа? - PullRequest
0 голосов
/ 16 апреля 2019

Я недавно использую Restful APIs с Android, я использую Retrofit для подключения моего API к своему Android-приложению, я пытаюсь вставить информацию о пользователе в свою базу данных PostgreSQL, но каждый раз, когда я вставляю новые данныемое приложение игнорирует метод onResponse и переходит непосредственно к onFailure, несмотря на успешную вставку и возврат кода 200. Как мне решить эту проблему?

Я использовал HttpLoggingInterceptor для регистрации ошибки, но он показывает код 200, которыйозначает, что со стороны сервера все в порядке.

Класс обслуживания Retrofit (UserService)

public interface UserService {
    //Return list of users
    @GET("/users")
    Call<List<User>> getUsers();
    //Post new user
    @POST("/users")
    Call<User> postUser(@Body User user);
}

Класс пользователя

public class User {

    @SerializedName("id")
    @Expose
    private Integer id;
    @SerializedName("name")
    @Expose
    private String name;
    @SerializedName("email")
    @Expose
    private String email;

    public Integer getId() {
        return id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getEmail() {
        return email;
    }

    public void setEmail(String email) {
        this.email = email;
    }

}

Модифицированное соединение и HttpLogging Instance

HttpLoggingInterceptor logging = new HttpLoggingInterceptor();
        logging.setLevel(HttpLoggingInterceptor.Level.BASIC);
        OkHttpClient.Builder httpClient = new OkHttpClient.Builder();

        httpClient.addInterceptor(logging);

        Retrofit retrofit = new Retrofit.Builder()
                .baseUrl(baseUrl)
                .addConverterFactory(GsonConverterFactory.create())
                .client(httpClient.build())
                .build();

FAB, запускающий вставку в MainActivity

FloatingActionButton fab = findViewById(R.id.fab);
        final User user = new User();
        user.setName("Michael");
        user.setEmail("michael@example.com");
        fab.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                userService.postUser(user).enqueue(new Callback<User>() {
                    @Override
                    public void onResponse(Call<User> call, Response<User> response) {
                        if(response.isSuccessful()) {
                            Toast.makeText(MainActivity.this, "User successfully inserted", Toast.LENGTH_SHORT).show();
                        }
                    }

                    @Override
                    public void onFailure(Call<User> call, Throwable t) {
                        Toast.makeText(MainActivity.this, "Error inserting into database", Toast.LENGTH_SHORT).show();
                    }
                });
            }
        });

Ответы [ 2 ]

0 голосов
/ 17 апреля 2019

Я все-таки нашел проблему.

Я отправлял ответ JSON от моего API, который был неправильно отформатирован, и Retrofit воспринял это как ошибку.

Вот скриншот моей новой функции API: http://prntscr.com/ncyxwx

0 голосов
/ 16 апреля 2019

Наверное, потому что преобразователь сгенерировал исключение. Вывести сбрасываемое сообщение об ошибке в методе onFailure. Если это просто несоответствие между вашим конвертером и данными на проводе, то это проблема приложения, которую нужно исправить.

См. Это для более

https://github.com/square/retrofit/issues/1446

Обновление после просмотра скриншота :

Это ошибка синтаксического анализа. В ответ он ожидает объект JSON пользовательского типа, но текущий ответ возвращает строку JSON.

...