использование Android HttpGet / HttpPost для связи с базой данных odbc: есть ли более быстрый способ?

#android #android-networking

#Android #android-сеть

Вопрос:

Я пишу приложение для использования устройства Android для получения и установки данных из базы данных Access в локальной сети. Я использую HttpPost и / или HttpGet для связи со страницами php на сервере, которые, в свою очередь, взаимодействуют с БД через odbc.

Это работает хорошо, но для завершения каждого запроса требуется почти секунда. Есть ли более быстрый способ?

Я отлаживаю через usb на самом устройстве. Когда я получаю доступ к страницам php из браузера на устройстве, это намного быстрее. В этой сети нет другого трафика.

Спасибо!

Редактировать: вот код для извлечения набора данных:

 private JSONArray getData(String phpFile,ArrayList<NameValuePair> nameValuePairs){

 String result = "";
 InputStream is = null;
 JSONArray jArray=null;

try{

   HttpClient httpclient = new DefaultHttpClient();

   HttpPost httppost = new HttpPost("http://"   mServerIP   "/dressageNet/"  phpFile);

   httppost.setEntity(new UrlEncodedFormEntity(nameValuePairs)); 

   HttpResponse response = httpclient.execute(httppost); 

   HttpEntity entity = response.getEntity();

         is = entity.getContent();

}catch(Exception e){ 
    Log.e("log_tag", "Error in http connection " e.toString());
}

try{

    BufferedReader reader = new BufferedReader(new InputStreamReader(is,"iso-8859-1"),8);
    StringBuilder sb = new StringBuilder();
    String line = null;
    while ((line = reader.readLine()) != null) {
            sb.append(line   "n");}
    is.close();
    result=sb.toString();

}catch(Exception e){
    Log.e("log_tag", "Error converting result " e.toString());
    }

try{

   jArray = new JSONArray(result);

}catch(JSONException e){
   Log.e("log_tag", "Error parsing data " e.toString());
   }

nameValuePairs.clear();
return jArray;
}
  

Комментарии:

1. Было бы проще, если бы вы опубликовали некоторый код, который покажет нам, как вы на самом деле используете методы get / post. Возможно, есть некоторые накладные расходы, которые не очевидны из вашего вопроса в его текущем состоянии.

Ответ №1:

Создайте пользовательское серверное приложение на любом желаемом языке и прекратите использовать http-сервер и PHP. PHP работает медленно, и это создает накладные расходы. конечно, вам нужно будет реализовать свой собственный протокол, но это будет намного быстрее. Я сделал что-то подобное в java me, и производительность была намного лучше, чем при выполнении POST / GET.