Я отправляю запрос / getsms GET
в API и получаю ожидаемые результаты от почтальона. Однако, когда я пытаюсь сделать тот же запрос через volley in java
на android studio
, он просто не получает response
, я продолжаю ждать, и ничего не происходит.
Я уверен, что API получает запрос, поскольку ожидаемые изменения происходят, когда I send the data associated with the get request
.
Так что я не понимаю, почему именно он не получает ответ.
Java код:
final String url = "http://10.0.2.2:3000/myroute/getsms/"+frm;
JsonObjectRequest getRequest = new JsonObjectRequest(Request.Method.GET, url, null,
new Response.Listener<JSONObject>()
{
@Override
public void onResponse(JSONObject response) {
try {
String frm = response.getString("src_num");
String msg = response.getString("msg");
int id = response.getInt("id");
itemsAdapter.add(frm + ": " + msg);
Log.d("Response", response.toString());
}
catch (Exception err) {
Log.d("excpetion", err.toString());
}
}
},
new Response.ErrorListener()
{
@Override
public void onErrorResponse(VolleyError error) {
Log.d("Error.Response", error.toString());
}
}
);
Код API:
router.get('/getsms/:dest_num', function (req, res) {
console.log("get oldest unsent sms from db");
let sql = "SELECT * FROM " + table + " WHERE " + "dest_num=" + req.params.dest_num + " AND sent=FALSE " + "ORDER BY id " + "LIMIT 1;";
console.log(sql);
db.mycon.query(sql, function (err, result) {
console.log("Result: " + JSON.stringify(result));
if(err){
res.send(err);
} else {
console.log("SENT!")
res.json(result);
}
});
});
Любая помощь приветствуется.
ОБНОВЛЕНИЕ: Таким образом, после просеивания через логи я нашел вот так:
2020-01-15 22:07:23.481 11880-11880/com.example.sms D/Error.Response: com.android.volley.ParseError: org.json.JSONException: Value [{"id":4,"src_num":"321","dest_num":"1003435365","msg":"first message from server","time":100,"sent":0}] of type org.json.JSONArray cannot be converted to JSONObject
Видимо ответ получен но Volley
пинает при разборе. Я не могу понять, почему это происходит. Я не вижу ничего плохого в строке JSON. И действительно ли этого достаточно для того, чтобы не go в функцию onResponse
?
ОБНОВЛЕНИЕ2: Итак, очевидно, что это действительно была проблема и что было отправлено был не JSONObject
, а JSONArray
. и просто нужно было соответственно изменить типы данных.
Итак, код перестал работать с:
String url = "http://10.0.2.2:3000/myroute/getsms/" + frm;
JsonArrayRequest jsonObjectRequest = new JsonArrayRequest(Request.Method.GET, url, null, new Response.Listener<JSONArray>() {
@Override
public void onResponse(JSONArray response_arr) {
try {
JSONObject response = response_arr.getJSONObject(0);
String frm = response.getString("src_num");
String msg = response.getString("msg");
int id = response.getInt("id");
itemsAdapter.add(frm + ": " + msg);
} catch (Exception err) {
System.out.println(err.toString());
}
}
}, new Response.ErrorListener() {
@Override
public void onErrorResponse(VolleyError error) {
Log.d("Error.Response", error.toString());
}
});
requestQueue.add(jsonObjectRequest);
Спасибо за комментарии за помощь:)