麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > ASP > 正文

asp 采集程序常用函數分析

2024-05-04 11:08:46
字體:
來源:轉載
供稿:網友
想用asp制作你喜歡的小偷采集程序嗎,看完下面的文章,你就可以自己制作了。
 
 
 
原理 
采集程序實際上是通過了XML中的XMLHTTP組件調用其它網站上的網頁。比如新聞采集程序,很多都是調用了sina的新聞網頁,并且對其中的html進行了一些替換,同時對廣告也進行了過濾。用采集程序的優點有:無須維護網站,因為采集程序中的數據來自其他網站,它將隨著該網站的更新而更新;可以節省服務器資源,一般采集程序就幾個文件,所有網頁內容都是來自其他網站。缺點有:不穩定,如果目標網站出錯,程序也會出錯,而且,如果目標網站進行升級維護,那么采集程序也要進行相應修改;速度,因為是遠程調用,速度和在本地服務器上讀取數據比起來,肯定要慢一些。 

一、事例 
下面就XMLHTTP在ASP中的應用做個簡單說明 
復制代碼代碼如下:

<% 
'常用函數 
'1、輸入url目標網頁地址,返回值getHTTPPage是目標網頁的html代碼 
function getHTTPPage(url) 
dim Http 
set Http=server.createobject("MSXML2.XMLHTTP") 
Http.open "GET",url,false 
Http.send() 
if Http.readystate<>4 then 
exit function 
end if 
getHTTPPage=bytesToBstr(Http.responseBody,"GB2312") 
set http=nothing 
if err.number<>0 then err.Clear 
end function 
'2、轉換亂瑪,直接用xmlhttp調用有中文字符的網頁得到的將是亂瑪,可以通過adodb.stream組件進行轉換 
Function BytesToBstr(body) 
dim objstream 
set objstream = Server.CreateObject("adodb.stream") 
objstream.Type = 1 
objstream.Mode =3 
objstream.Open 
objstream.Write body 
objstream.Position = 0 
objstream.Type = 2 
objstream.Charset = "GB2312" '轉換原來默認的UTF-8編碼轉換成GB2312編碼,否則直接用XMLHTTP組件調用有中文字符的網頁得到的將是亂碼 
BytesToBstr = objstream.ReadText 
objstream.Close 
set objstream = nothing 
End Function 
'下面試著調用http://www.companysz.com的html內容 
Dim Url,Html 
Url="http://www.companysz.com"; 
Html = getHTTPPage(Url) 
Response.write Html 
%> 

二、幾個常用的函數 
(一)InStr 函數 
描述 
返回某字符(string2)串在另一字符串(string1)中第一次出現的位置。 
語法 
InStr(string1, string2) 
例如: 
Dim SearchString, SearchChar 
SearchString ="http://www.companysz.com" ' 要在其中搜索的字符串。 
SearchChar = "jb51" ' 搜索 "jb51"。 
MyBK = Instr(SearchString, SearchChar) ' 返回 8 
'如果找不到則返回“0”,例如: 
SearchChar = "BK" 
MyBK = Instr(SearchString, SearchChar) ' 返回 0 
(二)Mid 函數 
描述 
從字符串中返回指定數目的字符。 
語法 
Mid(string, start, over) 
例如: 
Dim MyBK 
MyBK = Mid("我們的BK(www.google)設計", 7, 12) '截取字符串"我們的BK(www.google)設計"第7個字符以后的12個字符 
'此時MyBK的值就變成了"www.google" 
(三)Replace 函數 
Dim SearchString, SearchChar 
SearchString ="我們的BK設計是一個網站建設資源網站" ' 要在其中搜索的字符串。 
SearchString =Replace(SearchString,"BK設計","Www.google") 
'此時SearchString的值就變成了"我們的Www.google是一個網站建設資源網站" 

三、截取指定區域的HTML代碼 
例如我只想獲取以下HTML代碼中"<td>"和"</td>"之間的的文字部分: 
<html> 
<title>(www.google)谷歌搜索引擎</title> 
<body> 
<table> 
<tr><td></td></tr> 
<tr><td id="Content">BK(www.google)谷歌搜索引擎是個資源多多的站點……</td></tr> 
</table> 
</body> 
</html> 
<% 
…… 
Dim StrBK,start,over,RsBK 
StrBK=getHTTPPage(網頁的地址) 
start=Instr(StrBK,"<td id=""Content"">") '此處的作用是獲取字符串開始地方的定位。這里要有人問了:原來的代碼是<td id="Content">,怎么你這里調用的是<td id=""Content"">啊?答案:asp中(準確的說是VBscript中是用兩個雙引號來表示一個雙引號的,因為雙引號對于程序來說是個敏感字符。) 
over=Instr(StrBK,"…</td></tr>")'此處的作用是獲取字符串結束地方的定位。 
'這里又要有人問了:( :程序調用HTML代碼干嗎前面多出來3個點點"…"啊?答:提示:上面一行也有一個</td></tr>,如果這里用</td></tr>來定位的話,程序會錯誤地把上面一行的</td></tr>當成欲獲取字符串的結束部分了。 
RsBK=mid(StrBK,start,over-start) '此處的作用是取出StrBK中第start個字符到第over個字符之間的字符串。mid函數前面一節我也講過了;over-start是為了計算出開始位置和結束位置之間的距離,也就是字符數。 
response.write(RsBK) '最后輸出程序獲取的內容 
%> 
不要高興的太早,當你運行的時候,你會發現頁面的html代碼有錯誤,為什么呢?因為你獲取的html代碼是: 
<td id="Content">BK(www.google)谷歌搜索引擎是個資源多多的站點… 
看到了吧?有殘缺的HTML代碼??!怎么辦呢?start=Instr(StrBK,"<td id=""Content"">")這個語句獲取的是"<td id="Content">"在StrBK中的位置數,現在我們可以在程序語句的后面加上17,那么程序就會將位置指向<td id="Content">后面的那個字符. 
好的,程序將改成這樣: 
<% 
…… 
Dim StrBK,start,over,RsBK 
StrBK=getHTTPPage(網頁的地址) 
start=Instr(StrBK,"<td id=""Content"">") + 17 
over=Instr(StrBK,"…</td></tr>") '這里你也可以減去七(-7)把3個點去掉 
RsBK=mid(StrBK,start,over-start) 
response.write(RsBK) 
%> 
這樣就OK了,我們就可以將我們想要的東西偷過來顯示在我們自己的頁面了,呵呵~ 

四、刪掉或修改獲取的字符 
將RsBK中的"BK(www.google)"換成"BK": 
RsBK=replace(RsBK,"BK(www.google)","BK") 
或者直接把"(www.google)"刪掉: 
RsBK=replace(RsBK,"(www.google)","") 
好了,現在RsBK就變成了:"BK谷歌搜索引擎是個資源多多的站點……"了. 
但是事實中,有些情況可能replace函數是不適應的,比如我們想把某個字符串里面的所有連接都去掉.連接可能包括很多種類型,replace只能替代其中特定的一個,我們不可能用一個又一個對應的replace函數來替換吧? 
但可以使用正則表達式來代替此項工作。這里不細談了。 
(一)如何將對方網站的翻頁也處理成我們自己的呢? 
答案是:利用replace函數和頁面參數的傳遞。 
例如對方頁面里含有這樣的翻頁代碼:"<a href=2.htm>下一頁</a>",我們可以先利用上面講的內容,獲取這個字符串,然后用replace函數:RsBK=replace(RsBK,"<a href=","<a href=page.asp?Url=") 
然后再page.asp的程序里獲取Url的參數值,最后用采集技術獲取下一頁你想要的內容就可以了。 
(二)如何將獲取的內容入庫 
由于篇幅有限,這里簡單說一下. 
其實很簡單: 
將偷來的內容作一下處理,防止在寫入數據庫的時候出現sql注入錯誤,例如:replace(String,"'","''") 
然后執行一個插入數據庫操作的sql命令就ok了~ 
以上只是一些關于XMLHTTP組件的初級應用,實際上它還能實現的功能還有很多,比如說保存遠程圖片到本地服務器上,配合adodb.stream組件可以把獲取來的數據保存進數據庫。采集的作用和使用范圍都很廣。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 久久精品网址 | 亚洲人成网站在e线播放 | 国产精品亚洲一区二区三区在线观看 | 亚洲成人播放 | 轻点插视频 | 日本不卡一区二区在线观看 | 日韩视频在线观看免费视频 | 爱看久久 | 一区二区三视频 | 法国极品成人h版 | 中文字幕欧美亚洲 | 日本在线播放一区二区三区 | 天天舔天天插 | 国产亚洲精品影达达兔 | 久草在线观看福利视频 | 久久九九热re6这里有精品 | 欧美三级欧美成人高清www | 一区二区久久久久草草 | 91精品国产一区二区在线观看 | 韩国精品一区二区三区四区五区 | h视频免费在线 | 亚洲91网 | a视频在线看 | 亚洲最新无码中文字幕久久 | 97中文字幕第一一一页 | 在线免费观看毛片视频 | 欧美一级高潮片免费的 | 美女被免费网站在线软件 | 精品三区视频 | 九九热精品免费视频 | 久久国产精品电影 | 97久色| 激情宗合 | 91午夜理伦私人影院 | 依依成人精品视频 | 久久区二区 | 日本教室三级在线看 | 黄色大片大毛片 | 一级做受大片免费视频 | 国产精品亚洲一区二区三区久久 | 国产亚洲精品久久午夜玫瑰园 |