Я пытаюсь вызвать php-файл внутри цикла for, используя AsyncHttpClient после получения значений, которые я сохраняю в локальной БД.
Я отправляю параметры в свой php-файл, поскольку он требует извлечения данных из mySQL. Часть выборки работает нормально, но при сохранении данных у меня возникла проблема. На самом деле я сохраняю значения, полученные через php, а затем добавляю значение параметра в ту же таблицу БД.
Проблема в том, что когда я пытаюсь получить данные, циклы отправляют правильное значение параметра, но когда данные JSONARRAY принимаются и сохраняются в БД, значение параметра всегда является последним числом в цикле for. Вот код и пример:
private void getSubMenuValues()
{
for (int i = 0; i < localdb.getCountValue(); i++)
{
String Id2 = localdb.getValue().get(i).getID();
Log.e("DB","Value"+Id2); (All the id2 value is printed immeidately in Log.)
parent_ID = Id2;
Log.e("Outside Async","Value"+parent_ID);
final RequestParams requestParams = new RequestParams();
requestParams.put("SId", Id2);
final String uploadWebsite = url_grant_id_details;
AsyncHttpClient client = new AsyncHttpClient();
client.post(uploadWebsite, requestParams, new JsonHttpResponseHandler()
{
private JSONArray details;
private int success;
private String ImageURL;
private String IsChild;
private String SId;
private String SName;
@Override
public void onSuccess(int statusCode, Header[] headers, JSONObject response)
{
try
{
alldetails = response.getJSONArray("alldetail");
for (int i = 0; i < details.length(); i++)
{
JSONObject c = alldetails.getJSONObject(i);
SId = c.getString("SId");
SName = c.getString("SName");
IsChild = c.getString("IsChild");
ImageURL = c.getString("ImageURL");
Log.e("Inside HTTP REQUEST","Value"+parent_ID); (Value is always the last number in the loop)
localdb.setProfileDetails(SId, SName, IsChild, ImageURL, parent_ID);
}
}
catch (JSONException e)
{
e.printStackTrace();
}
}
@Override
public void onFailure(int statusCode, Header[] headers, Throwable throwable, JSONObject errorResponse)
{
super.onFailure(statusCode, headers, throwable, errorResponse);
Toast.makeText(Main.this, "Unable to connect to server. Check your network !!", Toast.LENGTH_SHORT).show();
}
});
}
}
Здесь первый лог перед parent_id=id2 выводит все значения сразу, а не по одному.
Что-то вроде этого:
03-15 12:36:27.060: E/DB(16205): Value 4
03-15 12:36:27.099: E/DB(16205): Value 3
03-15 12:36:27.130: D/dalvikvm(16205): GC_FOR_ALLOC freed 244K, 3% free 10191K/10472K, paused 16ms, total 16ms
03-15 12:36:27.146: E/DB(16205): Value 5
03-15 12:36:27.154: E/DB(16205): Value 63
03-15 12:36:27.169: E/DB(16205): Value 62
03-15 12:36:27.185: I/Choreographer(16205): Skipped 40 frames! The application may be doing too much work on its main thread.
03-15 12:36:27.701: V/AsyncHttpResponseHandler(16205): Progress 1376 from 628 (219%)
03-15 12:36:27.701: V/AsyncHttpResponseHandler(16205): Progress 1669 from 628 (266%)
03-15 12:36:27.716: E/Inside HTTP Request(16205): Value62
03-15 12:36:27.755: E/Inside HTTP Request(16205): Value62
03-15 12:36:27.787: E/Inside HTTP Request16205): Value62
Если вы проверите журнал: DB Value печатается сразу 4,3,5,63,62 И затем после http-запроса это всегда значение 62 в цикле.
Я не уверен, что именно происходит?
Может ли кто-нибудь помочь мне понять, почему это происходит и как вызвать асинхронный http-запрос внутри цикла?
Спасибо!