【发布时间】:2014-06-28 06:09:35
【问题描述】:
我尝试让我的应用程序使用 HttpUrlConnection 与我的 php 服务器进行通信。我写了一个在我的电脑上运行良好的类,但是当我在手机上执行它时,它根本不起作用。
这是我的代码:
String data = "username=" + URLEncoder.encode(username, "UTF-8") + "&password=" + URLEncoder.encode(password, "UTF-8") + "&remember=1";
connection = (HttpURLConnection) new URL(BASE_URL + "user/login/app").openConnection();
connection.setRequestMethod("POST");
connection.setRequestProperty("Content-Type", "application/x-www-form-urlencoded");
connection.setRequestProperty("Content-Length", String.valueOf(data.length()));
connection.setDoInput(true);
connection.setDoOutput(true);
DataOutputStream out = new DataOutputStream(connection.getOutputStream());
out.writeBytes(data);
out.flush();
out.close();
行 DataOutputStream out = new DataOutputStream(connection.getOutputStream());抛出此异常:
E/Cloud (10393): java.io.IOException
E/Cloud (10393): at libcore.net.http.HttpURLConnectionImpl.connect(HttpURLConnectionImpl.java:85)
E/Cloud (10393): at libcore.net.http.HttpURLConnectionImpl.getOutputStream(HttpURLConnectionImpl.java:194)
E/Cloud (10393): at com.andryr.runningpal.data.cloud.Cloud.login(Cloud.java:139)
E/Cloud (10393): at com.andryr.runningpal.data.SessionList$2.onLogin(SessionList.java:177)
E/Cloud (10393): at com.andryr.runningpal.ui.dialog.LoginDialogFragment$2.onClick(LoginDialogFragment.java:56)
E/Cloud (10393): at com.android.internal.app.AlertController$ButtonHandler.handleMessage(AlertController.java:169)
E/Cloud (10393): at android.os.Handler.dispatchMessage(Handler.java:99)
E/Cloud (10393): at android.os.Looper.loop(Looper.java:154)
E/Cloud (10393): at android.app.ActivityThread.main(ActivityThread.java:4624)
E/Cloud (10393): at java.lang.reflect.Method.invokeNative(Native Method)
E/Cloud (10393): at java.lang.reflect.Method.invoke(Method.java:511)
E/Cloud (10393): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:809)
E/Cloud (10393): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:576)
E/Cloud (10393): at dalvik.system.NativeStart.main(Native Method)
我在我的电脑上测试了这段代码,它没有抛出任何异常。 我的清单:
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<uses-permission android:name="android.permission.INTERNET" />
谢谢
【问题讨论】:
-
如何捕获异常?你能添加 e.getMessage() 吗?
-
Log.e("TAG",ex.getMessage());给我一个 NullPointerException E/AndroidRuntime(18020): java.lang.NullPointerException: println 需要一条消息 E/AndroidRuntime(18020): at android.util.Log.println_native(Native Method) E/AndroidRuntime(18020): at android. util.Log.e(Log.java:231)
-
您可以通过手机上的简单获取连接进行连接吗?只需尝试使用 HttpURLConnection 从 google.com 之类的页面读取
-
问题已解决。我尝试使用 HttpUrlConnection 从 google.com 读取数据,但它给了我一个 NetworkOnMainThreadException。我只需要将这段代码放在 AsyncTask 中..
-
@andryr 哦,该死的,我在回答后才注意到您的评论。好吧,随便:)
标签: java android httpurlconnection ioexception