如果你要看这篇文章,希望你对inputStream流的读取已经有所了解。
InputStream读取流有三个方法,分别为read(),read(byte[] b),read(byte[] b, int off, int len)。在从数据流里读取数据时,为图简单,经常用InputStream.read()方法。这个方法是从流里每次只读取读取一个字节,效率会非常低。更好的方法是用InputStream.read(byte[] b)或者InputStream.read(byte[] b,int off,int len)方法,一次读取多个字节。但是这些方法都不能一次性把流中的数据读取完整或不知道有没有读取完整。
遇到上面这个问题,网上有人提出用InputStream.available()方法
int count = in.available(); byte[] b = new byte[count]; in.read(b);
这个方法可以在读写操作前先得知数据流里有多少个字节可以读取。需要注意的是,如果这个方法用在从本地文件读取数据时,一般不会遇到问题,但如果是用于网络操作,就经常会遇到一些麻烦。这是因为网络通讯往往是间断性的,一串字节往往分几批进行发送。
我是真遇到上面说的问题了,最后的解决办法是使用readInputStream方法:
URL url = new URL (urlStr); HttpURLConnection conn = (HttpURLConnection)url.openConnection(); //设置超时间为3秒 conn.setConnectTimeout(3*1000); //防止屏蔽程序抓取而返回403错误 conn.setRequestProperty("User-Agent", "Mozilla/4.0 (compatible; MSIE 5.0; Windows NT; DigExt)"); //得到输入流 InputStream inputStream = conn.getInputStream(); byte[] getData = readInputStream(inputStream); inputStream.read(getData); String str = new String(getData); System.out.println ("打印内容:"+str);
原文地址:https://www.cnblogs.com/ddwarehouse/p/10127729.html
时间: 2024-10-02 11:02:33