Java实现利用搜索引擎收集网址的程序.docVIP

Java实现利用搜索引擎收集网址的程序.doc

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
我这里讲的不是怎用搜索引擎取到的,如果您需要某类网址信息数据,就跟我来一起研究一下,非常简单。   本文采用Java语言写成,以google和百度搜索引擎为对象。   我们要利用google、百度搜索引擎的搜索规则中的两条,关键字搜索和inurl搜索。什么是inurl搜索,就是你所要搜索的网址中本身带有的关键字,比如/post.asp ,这个网址就含有post.asp这样的关键字,在搜索引擎中填写规则是 inurl:post.asp,这是收集网址的关键,因为很多网址本身会带有特定的信息,比如软件发布的网页网址信息中多含有 publish、submit、tuijian这样的信息,如/publish.asp,这样的网址多是发布信息的网页,在结合网页中本身可能含有的关键字,就可以用搜索引擎搜索出结果,然后我们利用程序将结果取回,对HTML页面进行分析,去除没有用的信息,将有用的网址信息写入文件或者数据库,就可以给其它应用程序或者人来使用了。   第一步,用程序将搜索结果取回,先以百度为例,比如我们要搜索软件发布的网页,关键字采用 “软件发布 版本 inurl:publish.asp,先登录百度看看,将关键字写入,然后提交,在地址栏就会看到 /s?ie=gb2312bs=%C8%ED%BC%FE%B7%A2%B2%BC+%C8%ED%BC%FE%B0%E6%B1%BE+inurl%3Apublish.aspsr=z=cl=3f=8wd=%C8%ED%BC%FE%B7%A2%B2%BC+%B0%E6%B1%BE+inurl%3Apublish.aspct=0 ,中文关键字全都变成编码了,没有关系,我们在程序中直接用中文也是可以的,其中多个关键字用+号相连,去掉一些没有用的信息,我们可以把地址优化成 /s?lm=0si=rn=20ie=gb2312ct=0 wd=软件发布+版本+inurl%3Apublish%2Easppn=0cl=0,其中rn表示一页显示多少个结果,wd=表示你要搜索的关键字,pn表示从第几条开始显示,这个pn将是我们程序循环取结果的变量,每20条循环一次。我们用Java写的程序来模拟这个搜索的过程,用到的关键类为 .HttpURLConnection,.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(/s?lm=0si=rn=20ie=gb2312ct=0?wd=软件发布+版本+inurl%3Apublish%2Easppn=+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: ///search?q=软件发布+版本+inurl:publish.asphl=zh-CNlr= newwindow=1start=0sa=Nie=UTF-8,其中编码要用ie=UTF-8,start表示从第几条记录显示,需要注意的是google对浏览器还要检查,如果浏览器不符合它的要求,将返回错误代码,所以在模拟浏览器

文档评论(0)

精品资料 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档