做ASP小偷程序

 (一)如何截取指定区域的HTML代码?

  (对方网站的HTML代码在哪儿看?晕:IE浏览器>>查看>>源文件。不要告诉我你不知道IE是什么!),例如我只想获取以下HTML代码中"<td>"和"</td>"之间的的文字部分:

<html>
<title>网站爱好者__http://www.wwwfan.cn</title>
<body>
<table>
<tr><td></td></tr>
<tr><td id="Content">网站爱好者__http://www.wwwfan.cn是个网页制作资源多多的站点……</td></tr>
</table>
</body>
</html>

<%
……
Dim StrBK,start,over,RsBK
StrBK=getHTTPPage(网页的地址)
start=Instr(StrBK,"<td id=""Content"">") '此处的作用是获取字符串开始地方的定位。Instr函数在VBScript教程里说过了哦~
'这里要有人问了:原来的代码是<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函数在VBScript教程里也讲过了;over-start是为了计算出开始位置和结束位置之间的距离,也就是字符数。
response.write(RsBK) '最后输出程序获取的内容
%>

   不要高兴的太早,当你运行的时候,你会发现页面的html代码有错误,为什么呢?因为你获取的html代码是:

<td id="Content">网站爱好者__http://www.wwwfan.cn是个资源多多的站点…

   看到了吧?有残缺的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中的"网站爱好者__http://www.wwwfan.cn"换成"http://www.wwwfan.cn":
RsBK=replace(RsBK,"网站爱好者__","")
  好了,现在RsBK就变成了:"http://www.wwwfan.cn--是个网页制作资源多多的站点……"了。

(三)如何将对方网站的翻页也处理成我们自己的呢?

   答案是:利用replace函数和页面参数的传递。

   例如对方页面里含有这样的翻页代码:"<a href=2.htm>下一页",我们可以先利用上面讲的内容,获取这个字符串,然后用replace函数:RsBK=replace(RsBK,"<a href=","<a href=page.asp?Url=") 然后再page.asp的程序里获取Url的参数值,最后用小偷技术获取下一页你想要的内容就可以了。

(四)如何将获取的内容入库

  其实很简单:将偷来的内容作一下处理,防止在写入数据库的时候出现sql注入错误,例如:replace(String,"'","''")
然后执行一个插入数据库操作的sql命令就ok了~ !


原文地址:http://599cn.com/dispbbs.asp?BoardID=13&ID=5248&replyID=&skin=1

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值