java实现利用搜索引擎收集网址的程序

java实现利用搜索引擎收集网址的程序

ID:37397124

大小:32.50 KB

页数:3页

时间:2019-05-23

java实现利用搜索引擎收集网址的程序_第1页
java实现利用搜索引擎收集网址的程序_第2页
java实现利用搜索引擎收集网址的程序_第3页
资源描述:

《java实现利用搜索引擎收集网址的程序》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、我这里讲的不是怎么使用搜索引擎,而是怎么让程序利用搜索引擎来搜集网址,这有什么用?很有用!网上动辄有人叫卖网址数据库,如发布软件网址、邮件地址、论坛网址、行业网址,这些网址是怎么来的呢?不可能是人手工收集而来的,都是让程序利用搜索引擎取到的,如果您需要某类网址信息数据,就跟我来一起研究一下,非常简单。  本文采用Java语言写成,以google和百度搜索引擎为对象。  我们要利用google、百度搜索引擎的搜索规则中的两条,关键字搜索和inurl搜索。什么是inurl搜索,就是你所要搜索的网址中本身带有的关键字,比如ht

2、tp://www.xxx.com/post.asp,这个网址就含有post.asp这样的关键字,在搜索引擎中填写规则是inurl:post.asp,这是收集网址的关键,因为很多网址本身会带有特定的信息,比如软件发布的网页网址信息中多含有publish、submit、tuijian这样的信息,如http://www.xxx.com/publish.asp,这样的网址多是发布信息的网页,在结合网页中本身可能含有的关键字,就可以用搜索引擎搜索出结果,然后我们利用程序将结果取回,对HTML页面进行分析,去除没有用的信息,将有用的

3、网址信息写入文件或者数据库,就可以给其它应用程序或者人来使用了。  第一步,用程序将搜索结果取回,先以百度为例,比如我们要搜索软件发布的网页,关键字采用“软件发布版本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%B

4、C%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表示从第几条开始显示,

5、这个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++

6、;i <100)   {   ......   try {    url = new URL("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();    

7、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 += currentLi

8、ne;    }   } catch (IOException ex3) {}   ....   //本次搜索的结果已经放到totalstring中了,是一些HTML代码,需要下一步进行分析了。   }   再以google为例,稍微有些不同,google对浏览器进行了一些检测,编码也不同,URL为http://ww

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。