首页 | 联系我们 | 叶凡网络官方QQ群:323842844
游客,欢迎您! 请登录 免费注册 忘记密码
您所在的位置:首页 > 新闻中心 > 行业新闻 > 正文

名扬互联:Java获取URL链接的文件类型

作者:cocomyyz 来源: 日期:2013-12-7 9:19:53 人气:0 加入收藏 评论:0 标签:

在写网络爬虫的时候,需要根据链接来获取文件类型,将内容正确存储。之前我都是根据链接的后缀来判断的,比如:

http://img12.360buyimg.com/da/20120330/88_31_ZySDre.jpg

这个链接指向的文件就是个jpg文件。但是后来发现有诸如

http://jprice.360buyimg.com/getSkuPriceImgService.action?skuId=1850001109&origin=1&webSite=1&type=1的链接,这招就不灵了。后来谷歌百度了一下也没发现解决办法。后来机缘巧合在Java Network Programming上找到了一个办法:

URLConnection class provides two static methods to help programs figure out the MIME type of some data; you can use these if the content type just isn't available or if you have reason to believe that the content type you're given isn't correct。

就是说URLConnection提供了两种方法可以猜测(根据实测结果,这个猜测是相当的准)数据的MIME类型。

第一个是:

  1. public static String guessContentTypeFromName(String name)

这个方法根据URL文件部分的后缀名来判断类型,跟之前我的方法一样。这个不能解决上面那个问题。

第二个是:

  1. public static String guessContentTypeFromStream(InputStream in)  

这个方法是根据流的前面几个字节来判断类型,这个就不需要文件后缀名了,完全可以解决上面那个问题。

测试代码如下:

  1. BufferedInputStream bis = null;  

  2. HttpURLConnection urlconnection = null;  

  3. URL url = null;          

  4.        url = new URL(strUrl);  

  5.    urlconnection = (HttpURLConnection) url.openConnection();  

  6.    urlconnection.connect();  

  7. bis = new BufferedInputStream(urlconnection.getInputStream());  

  8.    System.out.println("file type:"+HttpURLConnection.guessContentTypeFromStream


本文网址:http://www.mingyangnet.com/html/hangye/1262.html
读完这篇文章后,您心情如何?
  • 0
  • 0
  • 0
  • 0
  • 0
  • 0
  • 0
  • 0
更多>>网友评论
发表评论
编辑推荐
  • 没有资料