HttpUrlConnection的getOutputStream方法会抛出IOException异常

5

我尝试使用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() 吗? - rickz
Log.e("TAG",ex.getMessage()); 给我一个空指针异常 E/AndroidRuntime(18020): java.lang.NullPointerException: println需要一个消息 E/AndroidRuntime(18020): at android.util.Log.println_native(本机方法) E/AndroidRuntime(18020): 在android.util.Log.e(Log.java:231) - andryr
你能否使用手机上的简单get连接进行连接?只需尝试使用HttpURLConnection从像google.com这样的页面读取即可。 - rickz
1
问题解决了。我尝试使用HttpUrlConnection从google.com读取数据,但它抛出了NetworkOnMainThreadException异常。我只需要将这段代码放在AsyncTask中即可。 - andryr
@andryr 哦,该死的,我回答后才注意到你的评论。无论如何 :) - Andrei
1个回答

5

可能您正在尝试在UI线程上执行网络操作,这在 Android 3.0+ 设备上是不允许的。它们会抛出异常,指示您正在UI线程上执行网络操作。

尝试使用 AsyncTask 或单独的 Thread 执行网络操作。


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接