Android:连接到本地主机上的服务器时连接超时设备
我无法弄清楚为什么会发生这种情况。我正在使用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();
请帮我克服了这种怪异的局面。
首先,你应该看到,如何打开本地主机在Android设备上。 因为在您的Android设备上,您无法正常访问本地主机。
你可以提供一些关于这个或任何有用的链接的想法,我会尝试一下! – Anupam
你可以搜索SO,为此链接之一http://stackoverflow.com/questions/4779963/how-can-i-access-my-localhost-from-my-android-device –
尝试增加连接超时......
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();
试过这个,没成功。更新我的代码。请参见。 – Anupam
你没有将新参数传递给HTTPCLIENT ... – SilentKiller
尝试了你的代码。没有进展,我仍然有同样的错误。 – Anupam
你可以增加连接时间.. 你试过了吗? – SilentKiller
你想连接到你的本地服务器? –
@SilentKiller不,我没有尝试过。怎么做? – Anupam