用采集程序的优点有:无须维护网站,因为采集程序中的数据来自其他网站,它将随着该网站的更新而更新;可以节省服务器资源,一般采集程序就几个文件,所有网页内容都是来自其他网站。缺点有:
不稳定,如果目标网站出错,程序也会出错,而且,如果目标网站进行升级维护,那么采集程序也要进行相应修改;速度,因为是远程调用,速度和在本地服务器上读取数据比起来,肯定要慢一些。
一、事例
下面就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函数来替换吧?
相关推荐:
SQL 随机查询 包括(sqlserver,mysql,access等)
Win2008远程控制确保安全的设置技巧
JavaScript弹簧振子超简洁版 完全符合能量守恒,胡克定理
jquery tree 可编辑节点实现代码(jquery一句话节点菜单)
asp.net FreeTextBox配置详解
asp.net ckeditor编辑器的使用方法
jQuery html()等方法介绍
修改插入时间不匹配问题
Javascript结合css实现网页换肤功能
Js文字背景行如流水特效
ASP 80040e14错误的解决方法
asp.net 实现动态显示当前时间(不用javascript不考虑开销)
phpmailer 中文使用说明(简易版)
Sql server2005 优化查询速度50个方法小结
添加FCKeditor插件需要注意的地方
SQLids.vbs 0.7(最终版,以后改成gui界面的)
正确维护配置Apache服务器的方法 保护系统安全
javascript select控件间内容互相移动
php self,$this,const,static,-&gt;的使用
ASP 三层架构 Convert类实现代码
没有form表单情况下敲回车键提交表单的js代码
一个链接按两种方式打开两个网址的方法
系统存储过程sp_MSforeachtable和sp_MSforeachdb使用说明
javascript 线性渐变三
jQuery 使用手册(五)
面向对象的编程思想在javascript中的运用上部
PHP 长文章分页函数 带使用方法,不会分割段落,翻页在底部
json 入门基础教程 推荐
动态创建类实例代码
Jquery 表单取值赋值的一些基本操作
SQL2005 四个排名函数(row_number、rank、dense_rank和ntile)的比较
IIS SHTML支持设置方法(SSI)
JavaScript读取中文cookie时的乱码问题的解决方法
VBScript 实现文字遮罩
理解 JavaScript 预解析
jQuery Ajax之load()方法
JS OOP包机制,类创建的方法定义
asp.net下利用js实现返回上一页的实现方法小集
The remote procedure call failed and did not execute的解决办法
php 生成饼图 三维饼图
JavaScript 语法集锦 脚本之家基础推荐
Cython 三分钟入门教程
LazyForm jQuery plugin 定制您的CheckBox Radio和Select
ASP.NET MVC学习笔记
JavaScript 核心参考教程 RegExp对象
javascript RegExp 对象属性与方法和应用
用sql获取某字符串中的数字部分的语句
jquery (show,fadeOut,Animate)简单效果
DBCC CHECKIDENT 重置数据库标识列从某一数值开始
php实现jQuery扩展函数