java - BufferedReader 抛出异常,我不知道为什么

标签 java android xml-parsing bufferedreader

public URL setUrl() throws Exception{
    System.out.println("1");
    URL iotd=new URL("http://www.nasa.gov/rss/image_of_the_day.rss");
    System.out.println("2");
    BufferedReader in=new BufferedReader(new InputStreamReader(iotd.openStream()));
    System.out.println("3");**//this never gets printed**

    //testing xml parser
    XmlPullParserFactory factory=XmlPullParserFactory.newInstance();
    factory.setNamespaceAware(true);
    System.out.println("4");
    XmlPullParser xpp=factory.newPullParser();
    System.out.println("5");
    xpp.setInput(in);
    System.out.println("6");

    int eventType=xpp.getEventType();
    System.out.println(eventType+"!!!!!!!!!!!!!!!!");
    while(eventType!=XmlPullParser.END_DOCUMENT){
        if(eventType==XmlPullParser.START_DOCUMENT){
            System.out.println("start");
        }
    }

    in.close();
    return iotd;

}

该程序永远不会打印出“3”,并且 logcat 中有如此多的警告,我很难破译发生了什么,因为我已经有一段时间没有使用 java 了。有任何想法吗?我正在关注这个代码示例...

http://docs.oracle.com/javase/tutorial/networking/urls/readingURL.html

并尝试修改它以解析 xml,但我什至还没有测试该部分。

这是 logcat 在打印“2”后立即给我的所有警告

07-10 05:31:30.610: W/System.err(534): android.os.NetworkOnMainThreadException
07-10 05:31:30.621: W/System.err(534):  at android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1099)
07-10 05:31:30.621: W/System.err(534):  at java.net.InetAddress.lookupHostByName(InetAddress.java:391)
07-10 05:31:30.621: W/System.err(534):  at java.net.InetAddress.getAllByNameImpl(InetAddress.java:242)
07-10 05:31:30.621: W/System.err(534):  at java.net.InetAddress.getAllByName(InetAddress.java:220)
07-10 05:31:30.621: W/System.err(534):  at libcore.net.http.HttpConnection.<init>(HttpConnection.java:71)
07-10 05:31:30.621: W/System.err(534):  at libcore.net.http.HttpConnection.<init>(HttpConnection.java:50)
07-10 05:31:30.621: W/System.err(534):  at libcore.net.http.HttpConnection$Address.connect(HttpConnection.java:351)
07-10 05:31:30.621: W/System.err(534):  at libcore.net.http.HttpConnectionPool.get(HttpConnectionPool.java:86)
07-10 05:31:30.621: W/System.err(534):  at libcore.net.http.HttpConnection.connect(HttpConnection.java:128)
07-10 05:31:30.630: W/System.err(534):  at libcore.net.http.HttpEngine.openSocketConnection(HttpEngine.java:308)
07-10 05:31:30.630: W/System.err(534):  at libcore.net.http.HttpEngine.connect(HttpEngine.java:303)
07-10 05:31:30.630: W/System.err(534):  at libcore.net.http.HttpEngine.sendSocketRequest(HttpEngine.java:282)
07-10 05:31:30.630: W/System.err(534):  at libcore.net.http.HttpEngine.sendRequest(HttpEngine.java:232)
07-10 05:31:30.630: W/System.err(534):  at libcore.net.http.HttpURLConnectionImpl.getResponse(HttpURLConnectionImpl.java:273)
07-10 05:31:30.630: W/System.err(534):  at libcore.net.http.HttpURLConnectionImpl.getInputStream(HttpURLConnectionImpl.java:168)
07-10 05:31:30.630: W/System.err(534):  at java.net.URL.openStream(URL.java:462)
07-10 05:31:30.630: W/System.err(534):  at com.wajumbie.nasadailyimage.RssParse.setUrl(RssParse.java:14)
07-10 05:31:30.630: W/System.err(534):  at com.wajumbie.nasadailyimage.NasaDailyImage.onCreate(NasaDailyImage.java:29)
07-10 05:31:30.630: W/System.err(534):  at android.app.Activity.performCreate(Activity.java:4465)
07-10 05:31:30.630: W/System.err(534):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1049)
07-10 05:31:30.630: W/System.err(534):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1920)
07-10 05:31:30.630: W/System.err(534):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1981)
07-10 05:31:30.640: W/System.err(534):  at android.app.ActivityThread.access$600(ActivityThread.java:123)
07-10 05:31:30.640: W/System.err(534):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1147)
07-10 05:31:30.640: W/System.err(534):  at android.os.Handler.dispatchMessage(Handler.java:99)
07-10 05:31:30.640: W/System.err(534):  at android.os.Looper.loop(Looper.java:137)
07-10 05:31:30.640: W/System.err(534):  at android.app.ActivityThread.main(ActivityThread.java:4424)
07-10 05:31:30.640: W/System.err(534):  at java.lang.reflect.Method.invokeNative(Native Method)
07-10 05:31:30.640: W/System.err(534):  at java.lang.reflect.Method.invoke(Method.java:511)
07-10 05:31:30.640: W/System.err(534):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784)
07-10 05:31:30.640: W/System.err(534):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551)
07-10 05:31:30.640: W/System.err(534):  at dalvik.system.NativeStart.main(Native Method)

最佳答案

出现NetworkOnMainThreadException。阅读 this link了解更多信息。还有this article .

关于java - BufferedReader 抛出异常,我不知道为什么,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11407531/

相关文章:

java - Google Dart AJAX 和 MVP 功能与 GWT 提供的功能对比

java - 从 android 调用时缺少必需的请求正文,但与 postman 一起工作正常

android - 如何根据新的配置变化重新调整 View ?

java - 解析,带来所有结果

android - 房间数据库事务回滚

java - 用 HTML 标签解析 CDATA 并获取内容

Java SAX 解析器和多个 ContentHandler

java - 我可以从运行时将 XmlAdapter 添加到 JAXB(不带注释)吗?

Java解析带有附加数据的xml文件

java - 如何获取任何给定 java 类中声明的方法