2

我正在制作一个使用 HttpURLConnection 检索网页内容的 android 程序。我是 Java 和 Android 的新手。

问题是:阅读器读取整个页面源,但在最后一次迭代中,它没有附加到 stringBuffer 的最后一部分。

使用调试器我已经确定,在最后一次循环迭代中,创建了字符串 buff,但 stringBuffer 只是不附加它。

我需要解析检索到的内容。有没有比使用字符串更好的方法来处理解析内容。我在许多其他网站上读过,Java 中的字符串大小仅受可用堆大小的限制。我也尝试过使用 StringBuilder 。

任何人都知道可能是什么问题。顺便说一句,随时建议对代码进行任何改进。

谢谢!

URL u;
    try {
        u = new URL("http://feeds.timesonline.co.uk/c/32313/f/440134/index.rss");
        HttpURLConnection c = (HttpURLConnection) u.openConnection();
        c.setRequestProperty("User-agent","Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1; .NET CLR 1.1.4322; InfoPath.1; .NET CLR 2.0.50727)");
        c.setRequestMethod("GET");
        c.setDoOutput(true);
       c.setReadTimeout(3000);
          c.connect();
        StringBuffer stringBuffer = new StringBuffer("");
        InputStream in = c.getInputStream();
        InputStreamReader inp = new InputStreamReader(in);
        BufferedReader reader = new BufferedReader(inp);
        char[] buffer = new char[3072];
        int len1 = 0;
        while ( (len1 = reader.read(buffer)) != -1 ) 
        {
            String buff = new String(buffer,0,len1);
            stringBuffer.append(buff);
        }
        String stranica = new String(stringBuffer);
        c.disconnect();
        reader.close();
        inp.close();
        in.close();
4

2 回答 2

1

您可能希望使用更简单的实现。或者,切换到使用HttpClient来检索数据,尤其是使用它们的ResponseHandler模式。

于 2010-05-22T17:58:57.673 回答
1

我在 J2SE 和 Android 上测试了您的代码并且运行良好。我添加了几行来比较 J2SE 的结果:

System.out.println("ITERATIONS: " + iterations);
System.out.println("LEN: " + stranica.length());
System.out.println("LAST 50 chars: "
        + stranica.substring(stranica.length() - 50, stranica
                .length()));

FileWriter fw = new FileWriter("/tmp/tmp-j2se.txt");
fw.write(stranica);
fw.close();

和安卓:

System.out.println("ITERATIONS: " + iterations);
System.out.println("LEN: " + stranica.length());
System.out.println("LAST 50 chars: "
        + stranica.substring(stranica.length() - 50, stranica
                .length()));

FileOutputStream fos = openFileOutput("tmp-and.txt",
        Context.MODE_WORLD_READABLE | Context.MODE_WORLD_WRITEABLE);

System.out.println(getFileStreamPath("tmp-and.txt")
        .getAbsolutePath());

fos.write(stranica.getBytes());
fos.close();

我比较了两个文件并且是相同的,但让我感到困惑的是两个平台上 String 返回的长度不匹配:

J2SE:

镜头:22479

安卓:

05-22 20:28:22.733: INFO/System.out(455): LEN: 22433

但是在Android平台上获得的文件大小也有22479字节的长度。在没有进一步调查的情况下我能找到的唯一解释是一些编码(可能是行/结尾)翻译是透明地完成的。

回到您的问题的重点,您的代码似乎(并证明)是正确的。您在哪个 Android 平台版本/硬件上测试您的代码?

于 2010-05-22T18:42:29.450 回答