最近用HttpURLConnection下载一个图片的时候,下载下来死活打不开,显示文件格式已经损坏,直觉这可能是个压缩文件,于是改成用winrar打开,果不其然。
进一步查看http head的Content-Encoding,没错是gzip,浏览器发现这个gzip报文头就会自动解压,而我们自己写代码就要用GZIPInputStream来处理了。
gzip这种压缩应该对html css js那些有很好的效果,但是对大部分格式的图片没什么卵用,压缩是要服务器付出代价的。
这地址上有gzip压缩各种格式图片的测试结果:http://www.webkaka.com/blog/archives/compression-gzip-for-bmp-images.html。
import java.io.File;
import java.io.FileOutputStream;
import java.io.InputStream;
import java.io.OutputStream;
import java.net.HttpURLConnection;
import java.net.URL;
import java.util.Iterator;
import java.util.Map;
import java.util.zip.GZIPInputStream;
public class Test {
public static void main(String[] args) throws Exception {
download("http://s00.qccr.com/qccr/g00/insurance/2016/09/c49c7e57d98f3893.png", "logo_7111.png", "C:/test");
}
public static void download(String urlString, String filename, String savePath) throws Exception {
URL url = new URL(urlString);
HttpURLConnection con = (HttpURLConnection)url.openConnection();
//con.connect();
System.out.println(con.getResponseCode());
System.out.println(con.getContentLength());
Map map = con.getHeaderFields();
Iterator it = map.keySet().iterator();
boolean gzip = false;
while (it.hasNext()) {
Object type = map.get(it.next());
if (type.toString().indexOf("gzip") != -1) {
gzip = true;
break;
}
}
System.out.println(con.getContentEncoding()); //也可以用con.getContentEncoding()来判断是否gzip
System.out.println(gzip);
//con.setConnectTimeout(5 * 1000);
InputStream is = con.getInputStream();
byte[] bs = new byte[1024];
int len;
File sf = new File(savePath);
if (!sf.exists()) {
sf.mkdirs();
}
OutputStream os = new FileOutputStream(sf.getPath() + "/" + filename);
if (!gzip) {
while ( (len = is.read(bs)) != -1 ) {
os.write(bs, 0, len);
}
} else {
GZIPInputStream gis = new GZIPInputStream(is);
while ( (len = gis.read(bs)) != -1 ) {
os.write(bs, 0, len);
}
}
os.flush();
os.close();
is.close();
}
}
谢谢
本文介绍了一次使用HttpURLConnection下载图片遇到的问题:图片被gzip压缩导致无法正常打开。通过检查HTTP头部信息并使用GZIPInputStream成功解决了该问题。
3504

被折叠的 条评论
为什么被折叠?



