java用HttpURLConnection和GZIPInputStream下载gzip压缩的图片 博客分类: java HttpURLConnectionGZIPInputStreamgzip
程序员文章站
2024-03-24 15:09:10
...
最近用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(); } }
谢谢