网站建设  下载中心 社区论坛 信息公告 MY小屋
联系我们
设为首页
加入收藏

 

当前位置:首页>>编程开发>>JAVA编程>>正文
注:打开慢时请稍等

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

http://www.iyit.net  日期:2007-5-19 9:10:43  来源:  点击:
参加讨论】 我这里讲的不是怎么使用搜索引擎,而是怎么让程序利用搜索引擎来搜集网址,这有什么用?很有用!网上动辄有人叫卖网址数据库,如发布软件网址、邮件地址、论坛网址、行业网址,这些网址是怎么来的呢?不可能是人手工收集而来的,都是让程序利用搜索引擎取到的,如果您需要某类网址信息数据,就跟我来一起研究一下,非常简单。

  本文采用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("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,代码如下:

本新闻共2页,当前在第1页  1  2  


编辑: [发送给好友] [打印本页] [关闭窗口] [返回顶部]
上一篇:JAVA开发者应该去的20个英文网站
下一篇:没有了
转载请注明来源:www.iyit.net
特别声明: 本站除部分特别声明禁止转载的专稿外的其他文章可以自由转载,但请务必注明出处和原始作者。文章版权归文章原始作者所有。对于被本站转载文章的个人和网站,我们表示深深的谢意。如果本站转载的文章有版权问题请联系编辑人员,我们尽快予以更正。

 相关文章
JAVA开发者应该去的20个英文网站 编程必备经典:Java常见问题集锦 Java语言入门级的十二大特色详细介绍
在SQL Server的存储过程中调用Com组件 漂亮的Slider效果类终于封装成功 JSP语法详解大全(3)
JSP语法详解大全(2) JSP语法详解大全(1) 写java程序最容易犯的21种错误 jsp
eval()函数(javascript) JavaScript小窍 从XML到Java代码的数据绑定之创建类 java缓冲区溢出编程心得
php里怎么实现javascript的unescape函数 有谁知道去除一个文本中的所有空格,用 初学Javascript之cookie篇(译)
JavaScript对象与数组参考大全 用Javascript 实现的Dual listbox javascript版的日期输入控件
用 JavaScript 来操作字符串 一个非常实用的Javascript类库 如何利用IE进行JavaScript脚本调试
JavaScript常用检测脚本 javascript 经典函数 Email地址加密javascript版
最新更新 热点排行 推荐新闻
Java实现利用搜索引擎收集网址的程序
JAVA开发者应该去的20个英文网站
编程必备经典:Java常见问题集锦
Java语言入门级的十二大特色详细介绍
eval()函数(javascript) JavaScript小
Java实现利用搜索引擎收集网址的程序
JAVA开发者应该去的20个英文网站
编程必备经典:Java常见问题集锦
Java语言入门级的十二大特色详细介绍
用Visual Basic实现P2P
VB中运用反射原理优化程序代码
动态的管理ASP.NET DataGrid数据列
锋芒毕露v3.1QQ最新空间代码
v3.1最新QQ空间代码--李宇春系列
≮血色的记忆≯最新腾讯QQ空间3.1代码
Java实现利用搜索引擎收集网址的程序
JAVA开发者应该去的20个英文网站
编程必备经典:Java常见问题集锦
Java语言入门级的十二大特色详细介绍
在ASP与ASP.NET之间共享对话状态(2)
Photoshop十余种漂亮照片边框简单制作
Photoshop实例教程:打造超炫发光圈
照片处理:Photoshop人物照片换头术
Photoshop实例:调出漂亮MM的唯美效果
比熊猫烧香更可怕 光标漏洞病毒现网络
一天出5变种 ANI蠕虫制造者称要买宝马
婚纱照片抠图与背景处理合成技巧
最易损坏电脑的小动作
解决了带javascript语句的链接全都打不
JAVA开发者应该去的20个英文网站
编程必备经典:Java常见问题集锦
Java语言入门级的十二大特色详细介绍
eval()函数(javascript) JavaScript小
给年轻工程师的“十大忠告” 
JAVA开发者应该去的20个英文网站
编程必备经典:Java常见问题集锦
Java语言入门级的十二大特色详细介绍
VB中运用反射原理优化程序代码
6月17日最新3.1版本QQ空间代码,最新的
电脑保护误区面面观
系统总蓝屏,原来内存不干净
cpu散热技巧方法和六大误区 
学习CSS布局心得
一天出5变种 ANI蠕虫制造者称要买宝马

vbscript和javascript

设置首 页 - 版权声明 - 广告服务 - 关于我们 - 联系我们 - 友情连接
Copyrights © 2004-2007 iYiT.Net All Rights Reserved.
网站合作、广告联系QQ:147007642、466949678
易特网络技术 点击这里给我发消息