文章导读:在新的一年中,各位网友都进入紧张的学习或是工作阶段。网学的各位小编整理了asp-网站生成静态页面,及网站数据采集的攻、防原理和策略的相关内容供大家参考,祝大家在新的一年里工作和学习顺利!
发布时间:2005年11月27日 晚
文章作者:翟振凯 (小琦)
交流方式:
个人站:http://www.xiaoqi.net
技术站:http://www.iisvs.net
商业站:http://www.iisvs.com
QQ:53353866 22336848
关于本文:
本着互联网共享主义精神,特写此文献给建站新手,授人以鱼,不如授人以渔,本文所讲的只是方法和原理,希
望大家看完此文,能够从中得到些帮助和启发。
本文从一个ASP程序员的角度用大量实例祥细介绍了动态网站如何生成静态页面原理,又从一个采集
程序开发者
的角度去祥细介绍了网站数据采集的原理及功防策略。
关于网站生成静态页面,为了让本文读者容易理解,文内列举了目前常用的多种生成静态页面的方法,其中用了
很多的实例代码进行说明。
关于网站数据采集攻防,作者本身是一个采集程序的开发者,同时作者也收集研究了多种采集
程序,列举了目前
国内比较流行的几种防采集策略,并对每种策略作了简单客观的分析评价,希望能给广大站长们提供一些帮助。此章节也
把作者
原创的防采集方法奉献给大家,目地是为了让大家了解,防采集,不防
搜索引擎,是可行的,有效的。
声明:希望各位朋友转载时,不要把原有作者版权去掉,谢谢合作。
由于本人写作水平有限,写的不好的地方,还请大家多多包涵,如要批评或意见,请加我QQ。
目前很多人都开始注重动态页面生成HTML页了,但选择哪种生成HTML的方法和防采集却不防搜索引擎的
问题却经常困扰大
家。解决此问题则是本文产生的原因。
首先祥细说一下常用的几种生成HTML的方法:
生成HTML方法主要步骤只有两个:
一、获取要生成的html文件的内容
二、将获取的html文件内容保存为html文件
我在这里主要说明的只是第一步:如何获取要生成的html文件的内容:
目前常用获取html文件的内容的方法有几下几种:
1、
str="<html标记>内容</html标记>"
str=str&"<html标记>内容</html标记><html标记>数据库读取内容....</html标记>....."
这种方法与是在脚本内写要生成的html内容,不太方便预览生成页面的内容,无法可视化布局页面,更改html
模板时会更
加复杂。
用这种方法的人很多,但我感觉这种方法是最不方便的。
2、
制作单独的HTML
模板页,动态的内容用特定的字符作为标记(如:有人用$title$标记为网页标题),用ADODB.Stream或者
Scripting.FileSystemObject将其
模板内容载入,然后再用替换方法把原先定好的标记替换为动态内容(如:Replace(载
入的
模板内容,"$title$",rs("title" ) ) )。
3、
用XMLHTTP或serverXMLHTTP获取动态页所显示的HTML内容,
我常用的生成html文件的实例:
''-----------------翟振恺(小琦)
''weburl是要获取的动态页地址
''getHTTPPage(weburl)是获取动态页内容的函数
weburl="http://"&Request.ServerVariables("SERVER_NAME")&"/contact.asp?id="&rs("id")&""‘指定动态页地址
body=getHTTPPage(weburl)''用函数取到动态页地址的内容
''-----------------翟振恺(小琦)
此方法最大的好处就是不用费力气专门去写静态的
模板页面,只是将原来就有的动态页面转换为HTML静态页面,但生成速
度不是太快。
我常用的生成HTML的方法就是第3种:用XMLHTTP获取动态页生成的HTML内容,再用ADODB.Stream或者
Scripting.FileSystemObject保存成html文件。
第二步是生成文件的方法:
ASP里常用的有用ADODB.Stream生成文件和Scripting.FileSystemObject生成文件两种
1、
Scripting.FileSystemObject生成文件方法:
''-----------------翟振恺(小琦)
Set fso = CreateObject("Scripting.FileSystemObject")
File=Server.MapPath("要生成文件路径和文件名.htm")
Set txt=fso.OpenTextFile(File,