首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >InputStream读取

InputStream读取
EN

Stack Overflow用户
提问于 2011-10-17 04:20:33
回答 3查看 2.2K关注 0票数 0

在我的时区睡个好觉。

我正在构建一个http机器人,当我从服务器收到响应时,我想创建两个things.First来打印响应的主体,因为我知道响应的主体是TEXT/HTML型的,所以我要做的第二件事是通过html解析器(在这个特定的例子中是NekoHtml)解析响应。代码片段:

代码语言:javascript
复制
    //Print the first call
    printResponse(urlConnection.getInputStream());
    document = new InputSource(urlConnection.getInputStream());
    parser.setDocument(document);

问题是,当我运行第一行(printResponse)时,第二行将抛出异常。现在问题来了->这是因为InputStream只能被读取一次?每次我们从输入流中读取字节时,字节都会被清除?我们如何从输入流中读取超过一次的内容?

提前感谢

诚挚的问候

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2011-10-17 04:23:51

将来自服务器的响应读取到字节数组中。然后,您可以创建一个ByteArrayInputStream来重复读取字节。

票数 0
EN

Stack Overflow用户

发布于 2011-10-17 04:40:46

除了Ted Hopp所说的之外,还可以看看Apache Commons IO库。您将发现:

获取输入流、完全读取它并在给定encoding

  • TeeInputStream中返回字符串的
  • IOUtils.toString(urlConnection.getInputStream(), "UTF-8")实用程序方法是一个InputStream装饰器,它将复制每个读取的字节,并将其复制到给定的输出流中。

应该行得通:

代码语言:javascript
复制
 InputStream is = new TeeInputStream(urlConnection.getInputStream(), System.out);
票数 5
EN

Stack Overflow用户

发布于 2011-10-17 04:50:34

正如泰德·霍普所说:

代码语言:javascript
复制
    byte [] bytes = new byte[urlConnection.getInputStream().available()];
    printResponse(new ByteArrayInputStream(bytes));
    document = new InputSource(new ByteArrayInputStream(bytes));
    parser.setDocument(document);
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/7787047

复制
相关文章

相似问题

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