Android Ошибка модификации при отправке запроса на размещение для весенней загрузки? - PullRequest
0 голосов
/ 16 июня 2020

, так что я работаю над своим проектом. Я использую пружинный пыльник в качестве задней части и android java в качестве передней части. По сути, я протестировал свою конечную точку через почтальона, и она сработала. Но когда я пытаюсь отправить данные json из моего приложения android, оно показало мне ошибку типа «Код ошибки 500: данный идентификатор не должен быть нулевым». То есть, я проверил свой код вызова через Log.d. Вот мой метод запроса на размещение:

 public void updateAddress(AddresslistResponse addresslistResponse){
        SharedPreferences preferences = getSharedPreferences("MyPref",0);
        String tokens = preferences.getString("userToken",null);
        Call<AddresslistResponse> call = mainInterface.editAddress("Bearer " + tokens, addresslistResponse);
        call.enqueue(new Callback<AddresslistResponse>() {
            @Override
            public void onResponse(Call<AddresslistResponse> call, Response<AddresslistResponse> response) {
                Log.d("Call request", call.request().toString());
                Log.d("Call request header", call.request().headers().toString());
                Log.d("Response raw header", response.headers().toString());
                Log.d("Response raw", String.valueOf(response.raw().body()));
                Log.d("Response code", String.valueOf(response.code()));

                try {
                    if(response.body()!=null)
                        Toast.makeText(EditDataAlamat.this," response message success "+response.body(),Toast.LENGTH_LONG).show();
                    if(response.errorBody()!=null)
                        Toast.makeText(EditDataAlamat.this," response message error "+response.errorBody().string(),Toast.LENGTH_LONG).show();

                }catch (Exception e){
                    e.printStackTrace();
                }
            }

            @Override
            public void onFailure(Call<AddresslistResponse> call, Throwable t) {
                Log.e("ERROR: ", t.getMessage());
            }
        });
    }

И вот мой вывод журнала:

2020-06-16 11:25:06.278 27478-27478/com.example.my_app D/Call request: Request{method=PUT, url=http://localhost:1111/address/update/, tags={class retrofit2.Invocation=com.example.my_app .Interface.MainInterface.editAddress() [Bearer eyJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJhZG1pbldTSFJJUyIsInNjb3BlcyI6IlJPTEVfQURNSU4iLCJpYXQiOjE1OTIyNzkwODksImV4cCI6MTU5Mj, AddresslistResponse{alamat2 = 'Jl. mangga',telp2 = 'SOLO',telp1 = 'BANDUNG',kota2 = '16512',kota1 = '4568156',alamat1 = 'JL ramai',noPegawai = '14141414'}]}}
2020-06-16 11:25:06.279 27478-27478/com.example.my_app D/Call request header: Authorization: Bearer eyJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJhZG1pbldTSFJJUyIsInNjb3BlcyI6IlJPTEVfQURNSU4iLCJpYXQiOjE1OTIyNzkwODksImV4cCI6MTU5MjM2NTQ4OX0.EdOBfplxy-RKfPcHA2vfk9PPvPv3UxoQua9ovKbgT7U
2020-06-16 11:25:06.279 27478-27478/com.example.my_app D/Response raw header: Content-Type: application/json;charset=UTF-8
    Transfer-Encoding: chunked
    Date: Tue, 16 Jun 2020 04:25:06 GMT
    Connection: close
2020-06-16 11:25:06.279 27478-27478/com.example.my_app D/Response raw: retrofit2.OkHttpCall$NoContentResponseBody@e938081
2020-06-16 11:25:06.280 27478-27478/com.example.my_app D/Response code: 500

На основе журнала, показанного выше, я уже передаю значение как JSON Object. Даже в почтальоне мне удалось отправить запрос на размещение в таком формате json:

{
    "noPegawai": "141414",
    "kota2": "SOLO",
    "telp2": "085264524",
    "alamat2": "Jl. mangga",
    "alamat1": "JL ramai",
    "kota1": "BANDUNG",
    "telp1": "0812856477"
}

Я уже пытаюсь изменить метод вызова при весенней загрузке, но все равно та же ошибка сохраняется показано:

@Transactional
    @Override
    public Alamat updateAlamat(Alamat address) {
        Optional<Alamat> newAddress = alamatRepository.findById(address.getNik());
        newAddress.get().setNoPegawai(address.getNik());
        newAddress.get().setAlamat1(address.getAlamat1());
        newAddress.get().setAlamat2(address.getAlamat2());
        newAddress.get().setKota1(address.getKota1());
        newAddress.get().setKota2(address.getKota2());
        newAddress.get().setTelp1(address.getTelp1());
        newAddress.get().setTelp2(address.getTelp2());
        return alamatRepository.save(newAddress.get());
    }

Я что-то пропустил? Я пытаюсь понять это в течение 2 дней, но все еще нет прогресса. Пожалуйста, помогите мне: D Спасибо.

1 Ответ

0 голосов
/ 16 июня 2020

Я нашел решение для этого. Итак, в моем классе модели я инициализировал имя поля на основе формата JSON из запроса GET, но вместо этого оно должно соответствовать формату запроса Put. Пример:

//field name for PUT method
@Serialized ("noPegawai")
private String id;

//field name for GET method
@Serialized ("NoPegawai")
private String id

Я не знаю, почему возникла эта проблема, прямо в моем поле таблицы это указано точно так же, как «NoPegawai», но элемент JAVA здесь может только читать его (который использует метод GET), но не может отправить его в метод PUT и вернул его как нулевое значение. Таким образом, я создал еще один класс модели с той же инициализацией, но с разными именами полей. В результате у меня есть 2 класса моделей с одинаковыми полями, но разными только в верхнем и нижнем регистрах. Один для метода PUT, а другой для метода GET.

Я не знаю, будет ли это правильным решением для других случаев, но в моем случае оно работает. Если кто-нибудь подскажет мне лучшее решение для этого, я буду признателен: D

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...