我这里讲的不是怎么使用搜烦引擎Q而是怎么让程序利用搜索引擎来搜集|址Q这有什么用Q很有用Q网上动辄有人叫卖网址数据库,如发布Y件网址、邮件地址、论坛网址、行业网址Q这些网址是怎么来的呢?不可能是人手工收集而来的,都是让程序利用搜索引擎取到的Q如果您需要某cȝ址信息数据Q就跟我来一LI一下,非常单?/p>
本文采用Java语言写成Q以google和百度搜索引擎ؓ对象?/p>
我们要利用google、百度搜索引擎的搜烦规则中的两条Q关键字搜烦和inurl搜烦。什么是inurl搜烦Q就是你所要搜索的|址中本w带有的关键字,比如http://www.xxx.com/post.asp ,q个|址含有post.aspq样的关键字Q在搜烦引擎中填写规则是 inurl:post.asp,q是攉|址的关键,因ؓ很多|址本n会带有特定的信息Q比如Y件发布的|页|址信息中多含有 publish、submit、tuijianq样的信息,如http://www.xxx.com/publish.asp,q样的网址多是发布信息的网,在结合网中本n可能含有的关键字Q就可以用搜索引擎搜索出l果Q然后我们利用程序将l果取回Q对HTML面q行分析Q去除没有用的信息,有用的|址信息写入文g或者数据库Q就可以l其它应用程序或者h来用了?/p>
W一步,用程序将搜烦l果取回Q先以百度ؓ例,比如我们要搜索Y件发布的|页Q关键字采用 “Y件发?版本 inurl:publish.asp",先登录百度看看,关键字写入Q然后提交,在地址栏就会看?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 ,中文关键字全都变成编码了Q没有关p,我们在程序中直接用中文也是可以的Q其中多个关键字用+Lq,L一些没有用的信息,我们可以把地址优化?http://www.baidu.com/s?lm=0&si=&rn=20&ie=gb2312&ct=0& wd=软g发布+版本+inurl%3Apublish%2Easp&pn=0&cl=0Q其中rn表示一|C多个l果Qwd=表示你要搜烦的关键字Qpn表示从第几条开始显C,q个pn是我们E序循环取结果的变量Q每20条@环一ơ。我们用Java写的E序来模拟这个搜索的q程Q用到的关键cMؓ java.net.HttpURLConnection,java.net.URLQ先写一个提交搜索的class,关键代码如下Q?/p>
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=软g发布+版本+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) {} .... //本次搜烦的结果已l放到totalstring中了Q是一些HTML代码Q需要下一步进行分析了?br />} 再以googleZQ稍微有些不同,googleҎ览器q行了一些检,~码也不同,URL为http: //www.google.com/search?q=软g发布+版本+inurl:publish.asp&hl=zh-CN&lr= &newwindow=1&start=0&sa=N&ie=UTF-8,其中~码要用ie=UTF-8,start表示从第几条记录昄Q需要注意的是googleҎ览器q要查,如果览器不W合它的要求Q将q回错误代码Q所以在模拟览器提交中Q我们要多加一行代码,修改关键部分要将http属性中的User-Agent讄为常用的览器,比如Mozilla/4.0,代码如下Q?/p>
try { http = (HttpURLConnection) url.openConnection(); http.setRequestProperty("User-Agent", "Mozilla/4.0"); http.connect(); urlstream = http.getInputStream(); }catch(Exception ef){};
W二步,对取回的HTML~码q行分析Q取出其中的有用|址信息Qƈ写入文g或者数据库Q由于这些搜索引擎都有网快照和怼|页{网址信息h在HTML中,我们要将q些|址信息剔除掉,剔除的关键就是找出其中的规律Q百度搜索引擎中的网快照和其它没有用的的地址都含有baiduq个关键字,而google中含有的无用|址信息含有关键?google和cache,我们根据这些关键字剔除无用|址信息。在Java中要对字W串q行分析必然要用?java.util.StringTokenizeq个c,用来字W串以特定的分隔W分开Qjava.util.regex.Pattern?java.util.regex.Matcher用来匚w字符Ԍ关键代码如下Q?/p>
class CompareStr { public boolean comparestring(String oristring,String tostring) { Pattern p=null; //正则表达?br /> Matcher m=null; //操作的字W串 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); //成功取到URLQ记录到文g?br /> } } } } 通过以上E序Q我们就可以攉到自p的网址信息了,q可以再写另外一个应用程序,Ҏ集到的网址信息q一步分析,取出自己需要的信息Q这里就不再累赘Q道理都是一L。最后需说明一点,google搜烦引擎搜烦所能返回的l果不能过1000条,q了1000条,q接提C“对不vQ?Google 为所有查询的l果数都不会过 1000 个。”,癑ֺ搜烦引擎q回的结果不能超q?00多条Q所以我们要搜烦时尽可能多加关键字,结果范围羃?/p>
|