婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > asp 小偷采集程序原理與常用函數方法

asp 小偷采集程序原理與常用函數方法

熱門標簽:外呼系統還用卡么 騰訊地圖標注商戶關閉 地圖標注服務哪家好 徐州人工智能電銷機器人好用嗎 西寧公司外呼系統平臺 長沙防封電銷卡品牌 武漢營銷電話機器人軟件 地圖標注宅基地 智能電銷機器人適用于哪些行業
用采集程序的優點有:無須維護網站,因為采集程序中的數據來自其他網站,它將隨著該網站的更新而更新;可以節省服務器資源,一般采集程序就幾個文件,所有網頁內容都是來自其他網站。缺點有:

不穩定,如果目標網站出錯,程序也會出錯,而且,如果目標網站進行升級維護,那么采集程序也要進行相應修改;速度,因為是遠程調用,速度和在本地服務器上讀取數據比起來,肯定要慢一些。

一、事例
下面就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.google的html內容
Dim Url,Html
Url="http://www.google";
Html = getHTTPPage(Url)
Response.write Html
%>


二、幾個常用的函數
InStr 函數
描述 返回某字符(string2)串在另一字符串(string1)中第一次出現的位置。
語法 InStr(string1, string2)
例如:
Dim SearchString, SearchChar
SearchString ="http://www.google" ' 要在其中搜索的字符串。
SearchChar = "blue1000" ' 搜索 "blue1000"。
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>BK(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函數來替換吧?

標簽:普洱 雅安 通遼 巴彥淖爾 荊門 鷹潭 通化 運城

巨人網絡通訊聲明:本文標題《asp 小偷采集程序原理與常用函數方法》,本文關鍵詞  asp,小偷,采集,程序,原理,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《asp 小偷采集程序原理與常用函數方法》相關的同類信息!
  • 本頁收集關于asp 小偷采集程序原理與常用函數方法的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 弋阳县| 白玉县| 日照市| 于都县| 鄂托克旗| 舞钢市| 邓州市| 乡城县| 黄平县| 敦煌市| 鹤庆县| 古田县| 阳江市| 博湖县| 万全县| 登封市| 上饶县| 客服| 逊克县| 辽宁省| 兰州市| 永寿县| 饶阳县| 达拉特旗| 扶余县| 浮山县| 武夷山市| 南昌市| 洱源县| 宁德市| 搜索| 遂平县| 宁远县| 崇明县| 上林县| 黄大仙区| 刚察县| 鸡泽县| 偃师市| 星子县| 花莲市|