, так что я работаю над своим проектом. Я использую пружинный пыльник в качестве задней части и 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 Спасибо.