java利用url实现网页内容的抓取

发布时间 - 2026-01-11 00:08:17    点击率:

闲来无事,刚学会把git部署到远程服务器,没事做,所以简单做了一个抓取网页信息的小工具,里面的一些数值如果设成参数的话可能扩展性能会更好!希望这是一个好的开始把,也让我对字符串的读取掌握的更加熟练了,值得注意的是JAVA1.8 里面在使用String拼接字符串的时候,会自动把你要拼接的字符串用StringBulider来处理,大大优化了String 的性能,闲话不多说,show my XXX code~

运行效果:

首先打开百度百科,搜索词条,比如“演员”,再按F12查看源码

然后抓取你想要的标签,注入LinkedHashMap里面就ok了,很简单是吧!看看代码罗

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.net.HttpURLConnection;
import java.net.URL;
import java.util.*;
/**
 * Created by chunmiao on 17-3-10.
 */
public class ReadBaiduSearch {
 //储存返回结果
 private LinkedHashMap<String,String> mapOfBaike;
 //获取搜索信息
 public LinkedHashMap<String,String> getInfomationOfBaike(String infomationWords) throws IOException {
  mapOfBaike = getResult(infomationWords);
  return mapOfBaike;
 }
 //通过网络链接获取信息
 private static LinkedHashMap<String, String> getResult(String keywords) throws IOException {
  //搜索的url
  String keyUrl = "http://baike.baidu.com/search?word=" + keywords;
  //搜索词条的节点
  String startNode = "<dl class=\"search-list\">";
  //词条的链接关键字
  String keyOfHref = "href=\"";
  //词条的标题关键字
  String keyOfTitle = "target=\"_blank\">";
  String endNode = "</dl>";
  boolean isNode = false;
  String title;
  String href;
  String rLine;
  LinkedHashMap<String,String> keyMap = new LinkedHashMap<String,String>();
  //开始网络请求
  URL url = new URL(keyUrl);
  HttpURLConnection urlConnection = (HttpURLConnection) url.openConnection();
  InputStreamReader inputStreamReader = new InputStreamReader(urlConnection.getInputStream(),"utf-8");
  BufferedReader bufferedReader = new BufferedReader(inputStreamReader);
  //读取网页内容
  while ((rLine = bufferedReader.readLine()) != null){
   //判断目标节点是否出现
   if(rLine.contains(startNode)){
    isNode = true;
   }
   //若目标节点出现,则开始抓取数据
   if (isNode){
    //若目标结束节点出现,则结束读取,节省读取时间
    if (rLine.contains(endNode)) {
     //关闭读取流
     bufferedReader.close();
     inputStreamReader.close();
     break;
    }
    //若值为空则不读取
    if (((title = getName(rLine,keyOfTitle)) != "") && ((href = getHref(rLine,keyOfHref)) != "")){
     keyMap.put(title,href);
    }
   }
  }
  return keyMap;
 }
 //获取词条对应的url
 private static String getHref(String rLine,String keyOfHref){
  String baikeUrl = "http://baike.baidu.com";
  String result = "";
  if(rLine.contains(keyOfHref)){
   //获取url
   for (int j = rLine.indexOf(keyOfHref) + keyOfHref.length();j < rLine.length()&&(rLine.charAt(j) != '\"');j ++){
    result += rLine.charAt(j);
   }
   //获取的url中可能不含baikeUrl,如果没有则在头部添加一个
   if(!result.contains(baikeUrl)){
    result = baikeUrl + result;
   }
  }
  return result;
 }
 //获取词条对应的名称
 private static String getName(String rLine,String keyOfTitle){
  String result = "";
  //获取标题内容
  if(rLine.contains(keyOfTitle)){
   result = rLine.substring(rLine.indexOf(keyOfTitle) + keyOfTitle.length(),rLine.length());
   //将标题中的内容含有的标签去掉
   result = result.replaceAll("<em>|</em>|</a>|<a>","");
  }
  return result;
 }
}

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!


# java实现网页数据抓取  # java实现网页内容抓取  # url抓取工具  # JavaWeb项目打开网页出现Session Error的异常解决方案  # java通过Jsoup爬取网页过程详解  # 详解java实现简单扫码登录功能(模仿微信网页版扫码)  # java调用微信接口实现网页分享小功能  # Java实现微信网页授权的示例代码  # Java实现的简单网页截屏功能示例  # 详解JAVA抓取网页的图片  # JAVA利用正则表达式抓取网站图片  # Java导出网页表格Excel过程详解  # 的是  # 无事  # 你要  # 我对  # 这是一个  # 很简单  # 如果没有  # 不含  # 会把  # 多说  # 也让  # 则在  # 你想要  # 值为  # 再按  # 小工具  # 闲来  # HttpURLConnection  # infomationWords  # getInfomationOfBaike 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 开心动漫网站制作软件下载,十分开心动画为何停播?  java ZXing生成二维码及条码实例分享  香港服务器租用每月最低只需15元?  Laravel模型关联查询教程_Laravel Eloquent一对多关联写法  Laravel怎么进行数据库回滚_Laravel Migration数据库版本控制与回滚操作  Laravel如何使用Socialite实现第三方登录?(微信/GitHub示例)  网站制作大概多少钱一个,做一个平台网站大概多少钱?  如何在阿里云部署织梦网站?  Python高阶函数应用_函数作为参数说明【指导】  Laravel怎么实现模型属性转换Casting_Laravel自动将JSON字段转为数组【技巧】  魔方云NAT建站如何实现端口转发?  如何用IIS7快速搭建并优化网站站点?  Laravel中DTO是什么概念_在Laravel项目中使用数据传输对象(DTO)  Laravel怎么实现验证码(Captcha)功能  Python图片处理进阶教程_Pillow滤镜与图像增强  零服务器AI建站解决方案:快速部署与云端平台低成本实践  JavaScript Ajax实现异步通信  laravel怎么配置和使用PHP-FPM来优化性能_laravel PHP-FPM配置与性能优化方法  如何在IIS中新建站点并解决端口绑定冲突?  Laravel怎么做数据加密_Laravel内置Crypt门面的加密与解密功能  Laravel的辅助函数有哪些_Laravel常用Helpers函数提高开发效率  简历没回改:利用AI润色让你的文字更专业  如何在IIS管理器中快速创建并配置网站?  如何用PHP工具快速搭建高效网站?  Laravel Telescope怎么调试_使用Laravel Telescope进行应用监控与调试  Laravel怎么实现验证码功能_Laravel集成验证码库防止机器人注册  Laravel如何实现数据导出到CSV文件_Laravel原生流式输出大数据量CSV【方案】  如何在阿里云ECS服务器部署织梦CMS网站?  Laravel怎么实现软删除SoftDeletes_Laravel模型回收站功能与数据恢复【步骤】  极客网站有哪些,DoNews、36氪、爱范儿、虎嗅、雷锋网、极客公园这些互联网媒体网站有什么差异?  如何快速生成凡客建站的专业级图册?  浅谈Javascript中的Label语句  Windows10如何删除恢复分区_Win10 Diskpart命令强制删除分区  如何自定义safari浏览器工具栏?个性化设置safari浏览器界面教程【技巧】  Laravel如何使用Scope本地作用域_Laravel模型常用查询逻辑封装技巧【手册】  Chrome浏览器标签页分组怎么用_谷歌浏览器整理标签页技巧【效率】  头像制作网站在线观看,除了站酷,还有哪些比较好的设计网站?  php后缀怎么变mp4格式错误_修改扩展名提示格式不对怎么办【技巧】  如何用花生壳三步快速搭建专属网站?  Laravel观察者模式如何使用_Laravel Model Observer配置  如何在服务器上三步完成建站并提升流量?  高性能网站服务器部署指南:稳定运行与安全配置优化方案  简单实现Android验证码  中国移动官方网站首页入口 中国移动官网网页登录  Laravel如何部署到服务器_线上部署Laravel项目的完整流程与步骤  Bootstrap整体框架之JavaScript插件架构  合肥制作网站的公司有哪些,合肥聚美网络科技有限公司介绍?  如何在Windows环境下新建FTP站点并设置权限?  5种Android数据存储方式汇总  PHP怎么接收前端传的文件路径_处理文件路径参数接收方法【汇总】