Java android 4.0.3上的应用程序因url.openStream()崩溃

Java android 4.0.3上的应用程序因url.openStream()崩溃,java,android,networkonmainthread,Java,Android,Networkonmainthread,当我试图在android 4.0.3 url.openStream()上解析json响应时,它崩溃了。但是,在2.3.3上,它是有效的 堆栈跟踪 try{ String stringURL = ""; ///some url URL url = new URL(stringURL); Reader reader = new InputStreamReader(url.openStream()); user = new Gs

当我试图在android 4.0.3 url.openStream()上解析json响应时,它崩溃了。但是,在2.3.3上,它是有效的

堆栈跟踪

 try{
         String stringURL = ""; ///some url
         URL url = new URL(stringURL);
         Reader reader = new InputStreamReader(url.openStream());
         user = new Gson().fromJson(reader, User.class);
        }
     catch (MalformedURLException e)
        {

        }
        catch (IOException e)
        {

        }
05-05 02:43:07.259:D/WebSettings(2172):mDataPath:/data/data/com.example.myvk
05-05 02:43:07.560:W/dalvikvm(2172):threadid=1:线程退出时出现未捕获异常(组=0x40c661f8)
05-05 02:43:07.580:E/AndroidRuntime(2172):致命异常:主
05-05 02:43:07.580:E/AndroidRuntime(2172):java.lang.RuntimeException:无法启动活动组件信息{com.example.myvk/com.example.myvk.wallacitivity}:android.os.networkMainThreadException
05-05 02:43:07.580:E/AndroidRuntime(2172):在android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1956)
05-05 02:43:07.580:E/AndroidRuntime(2172):在android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1981)
05-05 02:43:07.580:E/AndroidRuntime(2172):在android.app.ActivityThread.access$600(ActivityThread.java:123)
05-05 02:43:07.580:E/AndroidRuntime(2172):在android.app.ActivityThread$H.handleMessage(ActivityThread.java:1147)
05-05 02:43:07.580:E/AndroidRuntime(2172):在android.os.Handler.dispatchMessage(Handler.java:99)上
05-05 02:43:07.580:E/AndroidRuntime(2172):在android.os.Looper.loop(Looper.java:137)上
05-05 02:43:07.580:E/AndroidRuntime(2172):位于android.app.ActivityThread.main(ActivityThread.java:4424)
05-05 02:43:07.580:E/AndroidRuntime(2172):位于java.lang.reflect.Method.Invokenactive(本机方法)
05-05 02:43:07.580:E/AndroidRuntime(2172):位于java.lang.reflect.Method.invoke(Method.java:511)
05-05 02:43:07.580:E/AndroidRuntime(2172):在com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:787)
05-05 02:43:07.580:E/AndroidRuntime(2172):位于com.android.internal.os.ZygoteInit.main(ZygoteInit.java:554)
05-05 02:43:07.580:E/AndroidRuntime(2172):在dalvik.system.NativeStart.main(本机方法)
05-05 02:43:07.580:E/AndroidRuntime(2172):由以下原因引起:android.os.NetworkOnMainThreadException
05-05 02:43:07.580:E/AndroidRuntime(2172):在android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1105)
05-05 02:43:07.580:E/AndroidRuntime(2172):位于java.net.InetAddress.lookupHostByName(InetAddress.java:391)
05-05 02:43:07.580:E/AndroidRuntime(2172):位于java.net.InetAddress.getAllByNameImpl(InetAddress.java:242)
05-05 02:43:07.580:E/AndroidRuntime(2172):位于java.net.InetAddress.getAllByName(InetAddress.java:220)
05-0502:43:07.580:E/AndroidRuntime(2172):在libcore.net.http.HttpConnection.(HttpConnection.java:71)
05-05 02:43:07.580:E/AndroidRuntime(2172):在libcore.net.http.HttpConnection上(HttpConnection.java:50)
05-05 02:43:07.580:E/AndroidRuntime(2172):在libcore.net.http.HttpConnection$Address.connect(HttpConnection.java:351)
05-05 02:43:07.580:E/AndroidRuntime(2172):在libcore.net.http.HttpConnectionPool.get(HttpConnectionPool.java:86)
05-05 02:43:07.580:E/AndroidRuntime(2172):在libcore.net.http.HttpConnection.connect(HttpConnection.java:128)上
05-05 02:43:07.580:E/AndroidRuntime(2172):在libcore.net.http.HttpEngine.openSocketConnection(HttpEngine.java:308)
05-05 02:43:07.580:E/AndroidRuntime(2172):在libcore.net.http.HttpsURLConnectionImpl$HttpsEngine.makeSslConnection(HttpsURLConnectionImpl.java:460)
05-05 02:43:07.580:E/AndroidRuntime(2172):在libcore.net.http.HttpsURLConnectionImpl$HttpsEngine.connect(HttpsURLConnectionImpl.java:432)
05-05 02:43:07.580:E/AndroidRuntime(2172):在libcore.net.http.HttpEngine.sendSocketRequest(HttpEngine.java:282)
05-05 02:43:07.580:E/AndroidRuntime(2172):位于libcore.net.http.HttpEngine.sendRequest(HttpEngine.java:232)
05-05 02:43:07.580:E/AndroidRuntime(2172):在libcore.net.http.HttpURLConnectionImpl.getResponse(HttpURLConnectionImpl.java:273)
05-05 02:43:07.580:E/AndroidRuntime(2172):在libcore.net.http.HttpURLConnectionImpl.getInputStream(HttpURLConnectionImpl.java:168)
05-05 02:43:07.580:E/AndroidRuntime(2172):在libcore.net.http.HttpsURLConnectionImpl.getInputStream(HttpsURLConnectionImpl.java:270)
05-05 02:43:07.580:E/AndroidRuntime(2172):在com.example.myvk.WallActivity.loadProfile(WallActivity.java:73)
05-05 02:43:07.580:E/AndroidRuntime(2172):在com.example.myvk.WallActivity.onCreate(WallActivity.java:33)
05-05 02:43:07.580:E/AndroidRuntime(2172):在android.app.Activity.performCreate(Activity.java:4465)上
05-05 02:43:07.580:E/AndroidRuntime(2172):在android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1049)上
05-05 02:43:07.580:E/AndroidRuntime(2172):在android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1920)上
05-0502:43:07.580:E/AndroidRuntime(2172):。。。还有11个

这可能是由于蜂巢中引入的
NetworkOnMainThreadException
异常造成的。要解决这个问题,您应该在一个单独的线程中完成所有network-y任务(为了方便起见,您可以使用
AsyncTask


有关更多信息,请阅读以下博文:

这可能是由于蜂巢引入的
networkMainThreadException
异常所致。要解决这个问题,您应该在一个单独的线程中完成所有network-y任务(为了方便起见,您可以使用
AsyncTask


有关更多信息,请阅读此博文:

请提供异常消息和堆栈跟踪。请提供异常消息和堆栈跟踪。+1。这几乎肯定是原因,如果它能在安卓2.3上运行,但不能在较新版本上运行。这几乎肯定就是为什么它可以在安卓2.3上运行,但不能在新版本上运行的原因。
05-05 02:43:07.259: D/WebSettings(2172): mDataPath: /data/data/com.example.myvk
05-05 02:43:07.560: W/dalvikvm(2172): threadid=1: thread exiting with uncaught exception (group=0x40c661f8)
05-05 02:43:07.580: E/AndroidRuntime(2172): FATAL EXCEPTION: main
05-05 02:43:07.580: E/AndroidRuntime(2172): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.myvk/com.example.myvk.WallActivity}: android.os.NetworkOnMainThreadException
05-05 02:43:07.580: E/AndroidRuntime(2172):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1956)
05-05 02:43:07.580: E/AndroidRuntime(2172):     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1981)
05-05 02:43:07.580: E/AndroidRuntime(2172):     at android.app.ActivityThread.access$600(ActivityThread.java:123)
05-05 02:43:07.580: E/AndroidRuntime(2172):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1147)
05-05 02:43:07.580: E/AndroidRuntime(2172):     at android.os.Handler.dispatchMessage(Handler.java:99)
05-05 02:43:07.580: E/AndroidRuntime(2172):     at android.os.Looper.loop(Looper.java:137)
05-05 02:43:07.580: E/AndroidRuntime(2172):     at android.app.ActivityThread.main(ActivityThread.java:4424)
05-05 02:43:07.580: E/AndroidRuntime(2172):     at java.lang.reflect.Method.invokeNative(Native Method)
05-05 02:43:07.580: E/AndroidRuntime(2172):     at java.lang.reflect.Method.invoke(Method.java:511)
05-05 02:43:07.580: E/AndroidRuntime(2172):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:787)
05-05 02:43:07.580: E/AndroidRuntime(2172):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:554)
05-05 02:43:07.580: E/AndroidRuntime(2172):     at dalvik.system.NativeStart.main(Native Method)
05-05 02:43:07.580: E/AndroidRuntime(2172): Caused by: android.os.NetworkOnMainThreadException
05-05 02:43:07.580: E/AndroidRuntime(2172):     at android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1105)
05-05 02:43:07.580: E/AndroidRuntime(2172):     at java.net.InetAddress.lookupHostByName(InetAddress.java:391)
05-05 02:43:07.580: E/AndroidRuntime(2172):     at java.net.InetAddress.getAllByNameImpl(InetAddress.java:242)
05-05 02:43:07.580: E/AndroidRuntime(2172):     at java.net.InetAddress.getAllByName(InetAddress.java:220)
05-05 02:43:07.580: E/AndroidRuntime(2172):     at libcore.net.http.HttpConnection.<init>(HttpConnection.java:71)
05-05 02:43:07.580: E/AndroidRuntime(2172):     at libcore.net.http.HttpConnection.<init>(HttpConnection.java:50)
05-05 02:43:07.580: E/AndroidRuntime(2172):     at libcore.net.http.HttpConnection$Address.connect(HttpConnection.java:351)
05-05 02:43:07.580: E/AndroidRuntime(2172):     at libcore.net.http.HttpConnectionPool.get(HttpConnectionPool.java:86)
05-05 02:43:07.580: E/AndroidRuntime(2172):     at libcore.net.http.HttpConnection.connect(HttpConnection.java:128)
05-05 02:43:07.580: E/AndroidRuntime(2172):     at libcore.net.http.HttpEngine.openSocketConnection(HttpEngine.java:308)
05-05 02:43:07.580: E/AndroidRuntime(2172):     at libcore.net.http.HttpsURLConnectionImpl$HttpsEngine.makeSslConnection(HttpsURLConnectionImpl.java:460)
05-05 02:43:07.580: E/AndroidRuntime(2172):     at libcore.net.http.HttpsURLConnectionImpl$HttpsEngine.connect(HttpsURLConnectionImpl.java:432)
05-05 02:43:07.580: E/AndroidRuntime(2172):     at libcore.net.http.HttpEngine.sendSocketRequest(HttpEngine.java:282)
05-05 02:43:07.580: E/AndroidRuntime(2172):     at libcore.net.http.HttpEngine.sendRequest(HttpEngine.java:232)
05-05 02:43:07.580: E/AndroidRuntime(2172):     at libcore.net.http.HttpURLConnectionImpl.getResponse(HttpURLConnectionImpl.java:273)
05-05 02:43:07.580: E/AndroidRuntime(2172):     at libcore.net.http.HttpURLConnectionImpl.getInputStream(HttpURLConnectionImpl.java:168)
05-05 02:43:07.580: E/AndroidRuntime(2172):     at libcore.net.http.HttpsURLConnectionImpl.getInputStream(HttpsURLConnectionImpl.java:270)
05-05 02:43:07.580: E/AndroidRuntime(2172):     at com.example.myvk.WallActivity.loadProfile(WallActivity.java:73)
05-05 02:43:07.580: E/AndroidRuntime(2172):     at com.example.myvk.WallActivity.onCreate(WallActivity.java:33)
05-05 02:43:07.580: E/AndroidRuntime(2172):     at android.app.Activity.performCreate(Activity.java:4465)
05-05 02:43:07.580: E/AndroidRuntime(2172):     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1049)
05-05 02:43:07.580: E/AndroidRuntime(2172):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1920)
05-05 02:43:07.580: E/AndroidRuntime(2172):     ... 11 more