`

(转)Java实现利用搜索引擎收集网址的程序

    博客分类:
  • Java
阅读更多

我这里讲的不是怎么使用搜索引擎,而是怎么让程序利用搜索引擎来搜集网址,这有什么用?很有用!网上动辄有人叫卖网址数据库,如发布软件网址、邮件地址、论坛网址、行业网址,这些网址是怎么来的呢?不可能是人手工收集而来的,都是让程序利用搜索引擎取到的,如果您需要某类网址信息数据,就跟我来一起研究一下,非常简单。

  本文采用Java 语言写成,以google和百度 搜索引擎为对象。

  我们要利用google、百度搜索引擎的搜索规则中的两条,关键字搜索和inurl搜索。什么是inurl搜索,就是你所要搜索的网址中本身带有的关键字,比如http://www.xxx.com/post.asp ,这个网址就含有post.asp这样的关键字,在搜索引擎中填写规则是 inurl:post.asp,这是收集网址的关键,因为很多网址本身会带有特定的信息,比如软件发布的网页 网址信息中多含有 publish、submit、tuijian这样的信息,如http://www.xxx.com/publish.asp,这样的网址多是发布信息的网页,在结合网页中本身可能含有的关键字,就可以用搜索引擎搜索出结果,然后我们利用程序将结果取回,对HTML页面进行分析,去除没有用的信息,将有用的网址信息写入文件或者数据库,就可以给其它应用程序或者人来使用了。

  第一步,用程序将搜索结果取回,先以百度为例,比如我们要搜索软件发布的网页,关键字采用 “软件发布 版本 inurl:publish.asp",先登录百度看看,将关键字写入,然后提交,在地址栏就会看到 http://www.baidu.com/s?ie=gb2312&bs=%C8%ED%BC%FE%B7%A2%B2%BC+%C8%ED%BC%FE%B0%E6 %B1%BE+inurl%3Apublish.asp&sr=&z=&cl=3&f=8&wd=%C8%ED%BC%FE%B7%A2%B2%BC+%B0%E6%B1%BE+inurl%3Apublish.asp&ct=0 ,中文关键字全都变成编码了,没有关系,我们在程序中直接用中文也是可以的,其中多个关键字用+号相连,去掉一些没有用的信息,我们可以把地址优化成http://www.baidu.com/s?lm=0&si=&rn=20&ie=gb2312&ct=0&wd=软件发布+版本+inurl%3Apublish%2Easp&pn=0&cl=0,其中rn表示一页显示多少个结果,wd=表示你要搜索的关键字,pn表示从第几条开始显示,这个pn将是我们程序循环取结果的变量,每20条循环一次。我们用Java写的程序来模拟这个搜索的过程,用到的关键类为 java.net.HttpURLConnection,java.net.URL,先写一个提交搜索的class,关键代码如下:

class Search
{
 public URL url;
 public HttpURLConnection http;
 public java.io.InputStream urlstream;
 ......
 for(int i=0;i++;i<100)
 {
  ......
  try {
   url = new URL("http://www.baidu.com/s?lm=0&si=&rn=20&ie=gb2312&ct=0&wd=软件发布+版本+inurl%3Apublish%2Easp&pn="+beginrecord+"&cl=0");
  }catch(Exception ef){};
  try {
   http = (HttpURLConnection) url.openConnection();
   http.connect();
   urlstream = http.getInputStream();
  }catch(Exception ef){};
  java.io.BufferedReader l_reader = new java.io.
  BufferedReader(new java.io.InputStreamReader(urlstream));
  try {
   while ((currentLine = l_reader.readLine()) != null) {
    totalstring += currentLine;
   }
  } catch (IOException ex3) {}
  ....
  //本次搜索的结果已经放到totalstring中了,是一些HTML代码,需要下一步进行分析了。
}


  再以google为例,稍微有些不同,google对浏览器进行了一些检测,编码也不同,URL为http://www.google.com/search?q=软件发布+版本+inurl:publish.asp&hl=zh-CN&lr=&newwindow=1&start=0&sa=N&ie=UTF-8,其中编码要用ie=UTF-8,start表示从第几条记录显示,需要注意的是google对浏览器还要检查,如果浏览器不符合它的要求,将返回错误代码,所以在模拟浏览器提交中,我们要多加一行代码,修改关键部分要将http属性中的User-Agent设置为常用的浏览器,比如Mozilla/4.0,代码如下:

try {
 http = (HttpURLConnection) url.openConnection();
 http.setRequestProperty("User-Agent", "Mozilla/4.0");
 http.connect();
 urlstream = http.getInputStream();
}catch(Exception ef){};


  第二步,对取回的HTML编码进行分析,取出其中的有用网址信息,并写入文件或者数据库,由于这些搜索引擎都有网页快照和相似网页等网址信息混杂在HTML中,我们要将这些网址信息剔除掉,剔除的关键就是找出其中的规律,百度搜索引擎中的网页快照和其它没有用的的地址都含有baidu这个关键字,而google中含有的无用网址信息含有关键字 google和cache,我们就根据这些关键字剔除无用网址信息。在Java中要对字符串进行分析必然要用到java.util.StringTokenize这个类,用来将字符串以特定的分隔符分开,java.util.regex.Pattern和java.util.regex.Matcher用来匹配字符串,关键代码如下:

class CompareStr
{
 public boolean comparestring(String oristring,String tostring)
 {
  Pattern p=null; //正则表达式
  Matcher m=null; //操作的字符串
  boolean b;
  p = Pattern.compile(oristring,Pattern.CASE_INSENSITIVE);
  m = p.matcher(tostring);
  b = m.find();
  return b;
 }
}

class AnalyUrl
{
 ......
 StringTokenizer token = new StringTokenizer(totalstring,"<> \"");
 String firstword;
 CompareStrcompstr = new CompareStr();
 String dsturl = null;
 while (token.hasMoreTokens())
 {
  firstword = token.nextToken();
  if (!compstr.comparestring("google.com", firstword) && !compstr.comparestring("cache",firstword))
  {
   if (firstword.length() > 7)
   {
    dsturl = firstword.substring(6,firstword.length() - 1);
    WriteUrl(dsturl); //成功取到URL,记录到文件中
   }
  }
 }
}


  通过以上程序,我们就可以收集到自己要的网址信息了,还可以再写另外一个应用程序,对收集到的网址信息进一步分析,取出自己需要的信息,这里就不再累赘,道理都是一样的。最后需说明一点,google搜索引擎搜索所能返回的结果不能超过1000条,过了1000条,就直接提示“对不起,Google 为所有查询的结果数都不会超过 1000 个。”,百度搜索引擎返回的结果不能超过700多条,所以我们要搜索时尽可能多加关键字,将结果范围缩小。

分享到:
评论

相关推荐

    爬虫搜索,简单的搜索引擎,java爬虫,搜索引擎例子,爬虫demo,java实现互联网内容抓取,搜索引擎大揭密

    总的来说,通过Java实现的爬虫搜索和搜索引擎可以帮助我们高效地从互联网中获取和组织信息。这个"搜索引擎大揭密"的项目不仅展示了爬虫的基本工作原理,还揭示了如何使用Java技术构建一个简易的搜索系统,这对于学习...

    搜索引擎源代码用java、jsp编写的搜索引擎源代码

    在搜索引擎的实现中,Java通常用于处理数据抓取、索引构建、查询解析和结果排序等核心功能。它的强大性能和跨平台特性使得Java成为构建搜索引擎后端的理想选择。 JSP则是Java在Web开发中的一个重要组件,它允许...

    基于java开发的搜索引擎系统附源代码

    通过这个项目,学习者不仅可以掌握Java编程,还能深入了解搜索引擎的工作流程,以及如何利用Java生态系统中的各种工具和框架解决实际问题。这对于提升Java开发技能和对搜索引擎技术的理解大有裨益。

    基于java的全文搜索引擎Lucene

    Java全职搜索引擎Lucene是一个强大的开源工具,用于创建高效的全文索引和搜索功能。它由Apache软件基金会维护,被广泛应用于各种网站和应用程序中,以提供快速、精准的站内搜索体验。本教程将深入讲解如何使用Lucene...

    搜索引擎的研究与实现(Java)(含源码)

    本项目基于Java语言,提供了搜索引擎的实现,包括源码,可以帮助我们深入理解搜索引擎的工作原理和开发过程。 首先,我们要了解搜索引擎的基本架构,通常包括爬虫(Crawler)、索引(Indexer)、查询处理器(Query ...

    基于Java的混合搜索引擎.pdf

    综上所述,基于Java的混合搜索引擎充分利用了元搜索引擎和全文搜索引擎的优势,通过改进的架构设计和技术实现,极大地提升了搜索效率和质量。对于那些寻求更快速、更全面搜索体验的用户而言,这种新型的搜索引擎无疑...

    Java技术的搜索引擎研究与实现.pdf

    搜索引擎通常利用所谓的“蜘蛛程序”(又称网络爬虫)主动抓取网络上的页面信息,并定期更新数据以扩大搜索范围和服务质量。因此,搜索引擎成为用户获取信息的最重要工具之一,它使得浏览网页和寻找资料的过程更加...

    Java 项目-搜索引擎的设计与实现.zip

    这个Java项目旨在实现一个基本的搜索引擎,让我们逐一解析其中涉及的关键技术和知识点。 1. **全文搜索**:搜索引擎的核心是全文搜索功能,它要求程序能够理解并处理自然语言输入的查询。这通常涉及到分词...

    基于Java技术的智能化搜索引擎的研究与设计.pdf

    ### 基于Java技术的智能化搜索引擎的研究与设计 #### 概述 本文深入探讨了基于Java技术构建的智能化搜索引擎的研究与设计,特别是在Web信息挖掘领域中的应用。随着互联网的迅猛发展,网络上的信息量呈爆炸式增长,...

    java_报表打印与搜索引擎

    总的来说,Java报表打印和搜索引擎都是复杂且技术含量高的领域。jxl和iText为Java开发人员提供了强大的工具,用于创建专业级别的报表。而搜索引擎开发则需要深入理解信息检索理论,并具备解决性能问题的能力。学习并...

    用java做的网络蜘蛛搜索引擎

    标题中的“用java做的网络蜘蛛搜索引擎”指的是使用Java编程语言实现的一种网络爬虫技术,它能够在互联网上自动遍历网页,搜集信息,并构建一个可搜索的数据库。这种搜索引擎的工作原理类似于真实的蜘蛛在网中穿梭,...

    JAVA基于网络爬虫的搜索引擎设计与实现.pdf

    网络爬虫作为一种自动抓取网页信息的工具,可以协助搜索引擎收集、更新数据,满足特定用户群体的需求。 1.3 网络爬虫的工作原理 网络爬虫由多个组件组成,包括URL管理器、下载器、解析器和存储器。它首先从种子URL...

    面向主题的搜索引擎的设计与实现

    在本文中,我们将深入探讨这种搜索引擎的设计与实现过程,主要关注其核心技术和Java编程语言的应用。 1. **搜索引擎的基本原理** 搜索引擎的工作流程通常包括爬取、索引、查询处理和结果返回四个步骤。首先,爬虫...

    JAVA搜索引擎、网络爬虫

    在Java中开发搜索引擎和网络爬虫,可以利用以下技术框架: 1. **Apache Lucene**:一个高性能全文检索库,提供倒排索引和相关性计算等功能。 2. **Solr**:基于Lucene的搜索服务器,支持分布式搜索和集群部署。 3. ...

    基于vb的搜索引擎

    网络爬虫是自动抓取互联网信息的程序,它遍历网页,收集和存储数据,为搜索引擎提供索引基础。在这个项目中,VB被用于编写爬虫,抓取互联网上的数据,然后这些数据可能被索引并存储,以便用户通过搜索引擎进行查询。...

    基于J2EE架构的智能元搜索引擎系统设计与实现

    ### 基于J2EE架构的智能元搜索引擎系统设计与实现 #### 一、引言 随着互联网的快速发展,信息量呈爆炸性增长,如何有效地获取所需信息成为了亟待解决的问题。传统的搜索引擎通过索引网页来提供搜索服务,但往往...

    Spider_java.zip_Java spider_java 爬虫_spider_搜索引擎 爬虫_网络爬虫

    【标题】"Spider_java.zip" 是一个包含Java实现的网络爬虫项目的压缩包,主要针对搜索引擎数据抓取。这个项目的核心在于使用Java编程语言来构建一个能够自动化浏览网页、解析HTML内容并收集所需信息的程序。网络爬虫...

    中文搜索引擎

    总结来说,这个简单的中文搜索引擎项目展示了如何利用现有工具和技术实现一个基本的信息检索系统,涵盖了从网页抓取到搜索结果展示的全过程,尤其突出了Lucene在构建搜索引擎中的关键作用。通过对这些知识点的理解和...

Global site tag (gtag.js) - Google Analytics