分享好友 最新资讯首页 最新资讯分类 切换频道
网站建设公司推广/成都搜狗seo
2024-12-29 17:14

之前写过很多单页面python爬虫,感觉python还是很好用的,这里用java总结一个多页面的爬虫,迭代爬取种子页面的所有链接的页面,全部保存在tmp路径下。

1 序言

实现这个爬虫需要两个数据结构支持,unvisited队列(priorityqueue:可以适用pagerank等算法计算出url重要度)和visited表(hashset:可以快速查找url是否存在);队列用于实现宽度优先爬取,visited表用于记录爬取过的url,不再重复爬取,避免了环。java爬虫需要的工具包有httpclient和htmlparser1.5,可以在maven repo中查看具体版本的下载。

1目标网站:新浪  http://www.sina.com.cn/

2结果截图

下面说说爬虫的实现,后期源码会上传到github中,需要的朋友可以留言

二 爬虫编程

1创建种子页面的url

MyCrawler crawler = newMyCrawler();

crawler.crawling(new String[]{"http://www.sina.com.cn/"});

2初始化unvisited表为上面的种子url

LinkQueue.addUnvisitedUrl(seeds[i]);

3最主要的逻辑实现部分:在队列中取出没有visit过的url,进行下载,然后加入visited的表,并解析改url页面上的其它url,把未读取的加入到unvisited队列;迭代到队列为空停止,所以这个url网络还是很庞大的。注意,这里的页面下载和页面解析需要java的工具包实现,下面具体说明下工具包的使用。

while(!LinkQueue.unVisitedUrlsEmpty()&&LinkQueue.getVisitedUrlNum()<=1000)

{//队头URL出队列

String visitUrl=(String)LinkQueue.unVisitedUrlDeQueue();if(visitUrl==null)continue;

DownLoadFile downLoader=newDownLoadFile();//下载网页

downLoader.downloadFile(visitUrl);//该 url 放入到已访问的 URL 中

LinkQueue.addVisitedUrl(visitUrl);//提取出下载网页中的 URL

Set links=HtmlParserTool.extracLinks(visitUrl,filter);//新的未访问的 URL 入队

for(String link:links)

{

LinkQueue.addUnvisitedUrl(link);

}

}

4下面html页面的download工具包

publicString downloadFile(String url) {

String filePath= null;HttpClient httpClient= newHttpClient();//设置 Http 连接超时 5s

httpClient.getHttpConnectionManager().getParams().setConnectionTimeout(5000);GetMethod getMethod= newGetMethod(url);//设置 get 请求超时 5s

getMethod.getParams().setParameter(HttpMethodParams.SO_TIMEOUT, 5000);//设置请求重试处理

getMethod.getParams().setParameter(HttpMethodParams.RETRY_HANDLER,newDefaultHttpMethodRetryHandler());

try{int statusCode =httpClient.executeMethod(getMethod);//判断访问的状态码

if (statusCode !=HttpStatus.SC_OK) {

System.err.println("Method failed:"

+getMethod.getStatusLine());

filePath= null;

}

byte[] responseBody = getMethod.getResponseBody();//读取为字节数组//根据网页 url 生成保存时的文件名

filePath = "temp\"

+getFileNameByUrl(url, getMethod.getResponseHeader("Content-Type").getValue());

saveToLocal(responseBody, filePath);

}catch(HttpException e) {//发生致命的异常,可能是协议不对或者返回的内容有问题

System.out.println("Please check your provided http address!");

e.printStackTrace();

}catch(IOException e) {//发生网络异常

e.printStackTrace();

}finally{//释放连接

getMethod.releaseConnection();

}returnfilePath;

}

5html页面的解析工具包

public static SetextracLinks(String url, LinkFilter filter) {

Set links = new HashSet();try{

Parser parser= newParser(url);

parser.setEncoding("gb2312");//过滤 标签的 filter,用来提取 frame 标签里的 src 属性所表示的链接

NodeFilter frameFilter = newNodeFilter() {publicboolean accept(Node node) {if (node.getText().startsWith("frame src=")) {return true;

}else{return false;

}

}

};//OrFilter 来设置过滤 标签,和 标签

OrFilter linkFilter = new OrFilter(newNodeClassFilter(

LinkTag.class), frameFilter);//得到所有经过过滤的标签

NodeList list =parser.extractAllNodesThatMatch(linkFilter);for (int i = 0; i < list.size(); i++) {

Node tag=list.elementAt(i);if (tag instanceof LinkTag)// 标签

{

LinkTag link=(LinkTag) tag;

String linkUrl= link.getLink();//url

if(filter.accept(linkUrl))

links.add(linkUrl);

}else// 标签

{//提取 frame 里 src 属性的链接如

String frame =tag.getText();int start = frame.indexOf("src=");

frame=frame.substring(start);int end = frame.indexOf(" ");if (end == -1)

end= frame.indexOf(">");

String frameUrl= frame.substring(5, end - 1);if(filter.accept(frameUrl))

links.add(frameUrl);

}

}

}catch(ParserException e) {

e.printStackTrace();

}returnlinks;

}

6未访问页面使用PriorityQueue带偏好的队列保存,主要是为了适用于pagerank等算法,有的url忠诚度更高一些;visited表采用hashset实现,注意可以快速查找是否存在

public classLinkQueue {//已访问的 url 集合

private static Set visitedUrl = newHashSet();//待访问的 url 集合

private static Queue unVisitedUrl = newPriorityQueue();//获得URL队列

public staticQueue getUnVisitedUrl() {returnunVisitedUrl;

}//添加到访问过的URL队列中

public static voidaddVisitedUrl(String url) {

visitedUrl.add(url);

}//移除访问过的URL

public static voidremoveVisitedUrl(String url) {

visitedUrl.remove(url);

}//未访问的URL出队列

public staticObject unVisitedUrlDeQueue() {returnunVisitedUrl.poll();

}//保证每个 url 只被访问一次

public static voidaddUnvisitedUrl(String url) {if (url != null && !url.trim().equals("")&& !visitedUrl.contains(url)&& !unVisitedUrl.contains(url))

unVisitedUrl.add(url);

}//获得已经访问的URL数目

public static intgetVisitedUrlNum() {returnvisitedUrl.size();

}//判断未访问的URL队列中是否为空

public staticboolean unVisitedUrlsEmpty() {returnunVisitedUrl.isEmpty();

}

最新文章
2024前瞻:5个出海营销新趋势把握增长新机会
  洞悉全球营销趋势,是瞭望市场未来的望远镜。在数字化革命、文化多元的时代,只有保持敏捷、掌握趋势,方能超越竞争,使品牌
1数据恢复软件-EaseUS Data Recovery Wizard 16.2.4破解版
Replay AI 是一款AI翻唱和AI 生成音乐的免费工具。 用户只需上传歌曲及RVC 模型,即可制作AI翻唱。 Replay AI 除了可以制作翻唱
AI写歌效果究竟如何?他们用了之后这样说
长沙晚报掌上长沙5月31日讯(全媒体记者 肖舞)近期,AI创作的音乐大量涌现,既有歌曲也有电视电影配乐,甚至有专场音乐会,用AI
AISummit全球人工智能技术大会主会场盛况壮观,展示AI为世界带来美好未来
AI技术诞生不足百年,在经历了几次寒冬之后,在最近20年实现了飞跃式的发展,人工智能正逐步占领金融、信息、医疗、自动驾驶等领
AI也能进行艺术创作吗?
被认为属于人类独一无二的行为之一就是创造力。虽然许多动物物种都创造了外表惊人的物品或者构造,比如说蜘蛛的精妙蛛网或者园丁
ai智能证件照相机app(又名51证件照制作)下载v1.1.3 安卓最新版
ai智能证件照相机app顾名思义是以证件照为主要服务内容而设计的应用产品。这一款app是由深圳市杰深通科技有限公司官方旗下开发打
GoogleAds详解
Google Ads,原名Google AdWords,是Google公司主要的广告服务产品,也是Google的主要收入来源,AdWord
AI大模型、Agent模式、自定义知识库、LangChain是什么?
智能体的新时代:LLM在Agent中的应用与实践 一、引言 近年来,随着人工智能技术的飞速发展,尤其是大型语言模
AI绘画的技术背景与发展趋势
随着人工智能技术的不断进步与普及,AI绘画作为一种新兴的艺术形式,越来越受到艺术家的关注。它具有独特的优势,能够显著缩短创
AI诈骗成功率近 100%!潘多拉魔盒已开启?
防不胜防,10分钟就被AI骗走430万元!这是近日震惊全网的真实诈骗案件。话题#AI诈骗正在全国爆发#冲上网络热搜,和你通过社交软件