2012-10-15 191 views
1

我无法弄清楚为什么会发生这种情况。我正在使用PHP服务器并将数据从Android应用程序发布到服务器。当我使用模拟器时,所有的东西都能正常工作,但是当我使用我的Android设备进行测试时,我收到了连接超时错误。我使用的是我的服务器在Android设备上的同一网络。我在这里贴上我的控制台日志,这样,就可以得到这方面一个明确的想法:Android:连接到本地主机上的服务器时连接超时设备

10-15 12:09:25.593: W/System.err(24334): org.apache.http.conn.ConnectTimeoutException: Connect to /10.0.2.2:80 timed out 
10-15 12:09:25.609: W/System.err(24334): at org.apache.http.conn.scheme.PlainSocketFactory.connectSocket(PlainSocketFactory.java:121) 
10-15 12:09:25.609: W/System.err(24334): at org.apache.http.impl.conn.DefaultClientConnectionOperator.openConnection(DefaultClientConnectionOperator.java:156) 
10-15 12:09:25.609: W/System.err(24334): at org.apache.http.impl.conn.AbstractPoolEntry.open(AbstractPoolEntry.java:164) 
10-15 12:09:25.609: W/System.err(24334): at org.apache.http.impl.conn.AbstractPooledConnAdapter.open(AbstractPooledConnAdapter.java:119) 
10-15 12:09:25.609: W/System.err(24334): at org.apache.http.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector.java:359) 
10-15 12:09:25.609: W/System.err(24334): at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:555) 
10-15 12:09:25.609: W/System.err(24334): at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:487) 
10-15 12:09:25.609: W/System.err(24334): at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:465) 
10-15 12:09:25.609: W/System.err(24334): at com.example.insertuserdetails.MainActivity$1.onClick(MainActivity.java:78) 
10-15 12:09:25.609: W/System.err(24334): at android.view.View.performClick(View.java:2538) 
10-15 12:09:25.609: W/System.err(24334): at android.view.View$PerformClick.run(View.java:9152) 
10-15 12:09:25.609: W/System.err(24334): at android.os.Handler.handleCallback(Handler.java:587) 
10-15 12:09:25.609: W/System.err(24334): at android.os.Handler.dispatchMessage(Handler.java:92) 
10-15 12:09:25.609: W/System.err(24334): at android.os.Looper.loop(Looper.java:130) 
10-15 12:09:25.617: W/System.err(24334): at android.app.ActivityThread.main(ActivityThread.java:3689) 
10-15 12:09:25.617: W/System.err(24334): at java.lang.reflect.Method.invokeNative(Native Method) 
10-15 12:09:25.617: W/System.err(24334): at java.lang.reflect.Method.invoke(Method.java:507) 
10-15 12:09:25.617: W/System.err(24334): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:842) 
10-15 12:09:25.617: W/System.err(24334): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:600) 
10-15 12:09:25.617: W/System.err(24334): at dalvik.system.NativeStart.main(Native Method) 

这里是我的JSON代码:

String url = "http://10.0.2.2/insert_user_details.php"; 
       HttpClient client = new DefaultHttpClient(); 
       HttpParams params = client.getParams(); 
       HttpConnectionParams.setConnectionTimeout(params, 15000); 
       HttpPost httpPost = new HttpPost(url); 
       httpPost.setHeader("json", jsonObject.toString()); 
       StringEntity se = null; 
       se = new StringEntity(jsonObject.toString()); 
       se.setContentEncoding(new BasicHeader(HTTP.CONTENT_TYPE, 
         "application/json")); 
       httpPost.setEntity(se); 
       HttpResponse response = client.execute(httpPost); 
       int i = response.getStatusLine().getStatusCode(); 
       Toast.makeText(getBaseContext(), "Status: " + i, 
         Toast.LENGTH_LONG).show(); 

请帮我克服了这种怪异的局面。

+0

你可以增加连接时间.. 你试过了吗? – SilentKiller

+0

你想连接到你的本地服务器? –

+0

@SilentKiller不,我没有尝试过。怎么做? – Anupam

回答

0

首先,你应该看到,如何打开本地主机在Android设备上。 因为在您的Android设备上,您无法正常访问本地主机。

+0

你可以提供一些关于这个或任何有用的链接的想法,我会尝试一下! – Anupam

+0

你可以搜索SO,为此链接之一http://stackoverflow.com/questions/4779963/how-can-i-access-my-localhost-from-my-android-device –

0

尝试增加连接超时......

HttpParameters = new BasicHttpParams(); 
HttpConnectionParams.setSoTimeout(httpParameters, timeoutConnection + 10000); 
HttpConnectionParams.setConnectionTimeout(httpParameters, timeoutConnection); 
httpclient = new DefaultHttpClient(httpParameters); 

代码:所有的

   String url = "http://10.0.2.2/insert_user_details.php"; 
      HttpPost httpPost = new HttpPost(url); 
      HttpParams params = new BasicHttpParams(); 
      HttpConnectionParams.setConnectionTimeout(params, 15000); 
      HttpClient client = new DefaultHttpClient(params); 
      httpPost.setHeader("json", jsonObject.toString()); 
      StringEntity se = null; 
      se = new StringEntity(jsonObject.toString()); 
      se.setContentEncoding(new BasicHeader(HTTP.CONTENT_TYPE, "application/json")); 
      httpPost.setEntity(se); 
      HttpResponse response = client.execute(httpPost); 
      int i = response.getStatusLine().getStatusCode(); 
      Toast.makeText(getBaseContext(), "Status: " + i, Toast.LENGTH_LONG).show(); 
+0

试过这个,没成功。更新我的代码。请参见。 – Anupam

+0

你没有将新参数传递给HTTPCLIENT ... – SilentKiller

+0

尝试了你的代码。没有进展,我仍然有同样的错误。 – Anupam

相关问题