使用Java HttpURLConnection抓取网页内容(一)限制返回的网页大小

  最近接到一个新的需求,要求给定一个url地址,获取该网页的title和图标地址,大致的思路是使用HttpUrlConnection抓取网页的源码,然后使用正则表达式匹配网页的标题和图标。

开发测试的过程中遇到了N多问题,简单总结一下;

(一).限制返回的网页大小

  在使用HttpUrlConnection获取网页内容时,最基本的做法就是获取http输入流,然后读取完整的网页内容,最后关闭输入流和http连接,但这里需要考虑的就是由于需求只是为了获取网页头信息中的title和icon,因此不需要下载完整的网页内容,只需要保证取到完整的头信息就行,思路就是从http输入流中读取指定大小的数据。

 1 try (InputStream inputStream = httpURLConnection.getInputStream();
 2       InputStreamReader inputStreamReader = new InputStreamReader(inputStream);
 3       BufferedReader reader = new BufferedReader(inputStreamReader);) {
 4 
 5                 // 只获取10KB的数据
 6                 char[] chars = new char[10 * 1024];
 7                 reader.read(chars, 0, 10 * 1024);
 8 
 9                 httpURLConnection.disconnect();
10                 return new String(chars);
11             }

  验证了几个比较大型的网站,10KB的数据足够获取到head信息。

 
 

 

转载于:https://www.cnblogs.com/superzong/p/6437056.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值