首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >HttpUrlConnection getOutputStream throws

HttpUrlConnection getOutputStream throws
EN

Stack Overflow用户
提问于 2014-05-10 15:03:46
回答 1查看 4.8K关注 0票数 5

我试图让我的应用程序使用HttpUrlConnection与我的php服务器进行通信。我在我的电脑上写了一个很好的类,但是当我在手机上执行它时,它根本不工作。

这是我的代码:

代码语言:javascript
复制
            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(connection.getOutputStream());out = DataOutputStream引发此异常:

代码语言:javascript
复制
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)

我在我的电脑上测试了这段代码,它不会抛出任何异常。我的舱单:

代码语言:javascript
复制
    <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" />

谢谢

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-08-23 16:12:44

可能您试图在UI线程上执行网络操作,Android 3.0+设备不允许这样做。它们将引发一个异常,指示您正在UI线程上执行网络操作。

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

票数 5
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/23582621

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档