想用FileInputStream从服务器上读取文件,然后通过ServletOutputStream输出, 这里有一个前提是:通过InputSteam中available方法返回的字节数小于1024,所以写如下的代码是可以正常工作的: FileInputStream fis = new FileInputStream("fileName"); ServletOutputStream sos = response.getOutputStream(); byte[] buf = new byte[fis.available()]; fis.read(buf); sos.write(buf); 但是之前也写了一段代码,如下: byte[] buf = new byte[1024];//file bytes less than 1024 fis.read(buf); sos.write(buf); 在客户端去获取字节的时候总是出现读取超时,开始百思不得其解,最后,比较一下两端代码,明白了: 文件的长度小于1024,第二段代码中将会出现有一部分字节空余,这样在通过ServletOutputStream传输的时候会出错。 结论:在使用InputStream和OutputStream的read(byte[])和write(byte[])处理字节流时,最好确保数组每次都读满。 由这个结论联想到另外一个问题:读取文件的内容,将其打印出来,在网上看到不少代码,不少像下面这样: while(fis.read(buf)!=-1){ System.out.println(new String(buf)); } 总觉得这段代码有问题:如果最后一次读取的字节数小于buf字节数组的长度,那buf中余下的字节将如何处理; 个人的想法是,余下的字节将使用上一次读取的字节的后面的几位。于是验证了一下,发现结果却是如此, 比如,文件中的内容是123456789,buf长度是8,在输出的结果,第一行是12345678,第二行是92345678。 使用下面代码避免这种错误: int byteLength = 8; byte[] buf = new byte[byteLength]; try { int fLength = fis.available(); int times = fLength/byteLength+1; int mod = fLength%byteLength; for(int i=1; i<=times; i++){ while(fis.read(buf)!= -1){ System.out.println(new String(buf)); if(i+1==times){ buf = new byte[mod]; } } } } catch (IOException e) { e.printStackTrace(); }