使用Android HttpGet / HttpPost与odbc数据库进行通信:有更快的方法吗?

时间:2011-10-01 13:03:12

标签: android android-networking

我正在编写一个应用程序,使用Android设备从局域网上的Access数据库获取和设置数据。我正在使用HttpPost和/或HttpGet与服务器上的php页面进行通信,而php页面又通过odbc与db进行通信。

效果很好,但每个查询都需要几秒钟才能完成。有更快的方法吗?

我正在通过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 个答案:

答案 0 :(得分:0)

以您想要的语言创建自定义服务器应用程序,并停止使用http服务器和PHP。 PHP很慢,这会产生开销。当然,你需要实现自己的协议,但速度要快得多。我在java中做了类似的事情,性能比POST / GET更好。