asp网页生成静态htm文件的方法

目前生成静态的ASP大概有三种例子:
1将下面存为一个ASP文件即可,IIS只要开启了FSO就可以测试运行:
<%
filename="test.htm" ‘设置生成的文件名
if request("body")<>"" then
set fso = Server.CreateObject("Scripting.FileSystemObject")
set htmlwrite = fso.CreateTextFile(server.mappath(""&filename&""))
htmlwrite.write "<html><head><title>" & request.form("title") & "</title></head>"           ‘开始写入内容
htmlwrite.write "<body>输出Title内容: " & request.form("title") & "<br /> 输出Body内容:" & request.form("body")& "</body></html>"
htmlwrite.close
set fout=nothing
set fso=nothing
end if
%>
<form name="form" method="post" action="">
<input name="title" value="Title" size=26>
<br>
<textarea name="body">Body</textarea>
<br>
<br>
<input type="submit" name="Submit" value="生成html">
</form>

但是按照上面的方法生成html文件非常不方便,第二种方法就是利用模板技术,将模板中特殊代码的值替换为从表单或是数据库字段中接受过来的值,完成模板功能;将最终替换过的所有模板代码生成HTML文件.这种技术采用得比较多,大部分的CMS都是使用这类方法.

随便做一个模版文件:template.htm
标记$title$为标题
标记$body$为内容

<html>
<head>
<title>$title$ by xiya.cn</title>
</head>
<body>
$body$
</body>
</html>

下面是TestTemplate.asp ‘// 生成Html
和模版文件放在同一个目录,运行即可。

<%
Dim fso,htmlwrite
Dim strTitle,strContent,strOut
‘// 创建文件系统对象
Set fso=Server.CreateObject("Scripting.FileSystemObject")
‘// 打开网页模板文件,读取模板内容
Set htmlwrite=fso.OpenTextFile(Server.MapPath("Template.htm"))
strOut=htmlwrite.ReadAll
htmlwrite.close
strTitle="生成的网页标题"
strContent="生成网页内容By xiya.net"
‘// 用真实内容替换模板中的标记
strOut=Replace(strOut,"$title$",strTitle)
strOut=Replace(strOut,"$body$",strContent)
‘// 创建要生成的静态页
Set htmlwrite=fso.CreateTextFile(Server.MapPath("test.htm"),true)
‘// 写入网页内容
htmlwrite.WriteLine strOut
htmlwrite.close
Response.Write "生成静态页成功!"
‘// 释放文件系统对象
set htmlwrite=Nothing
set fso=Nothing
%>

第三种方法就是用XMLHTTP获取动态页生成的HTML内容,再用ADODB.Stream或者Scripting.FileSystemObject保存成html文件。这句话是在蓝色理想上看到的,对XMLHTTP吟清还不熟悉正在找资料了解.找到一段XMLHTTP生成Html的代码参考一下.

<%
‘常用函数
‘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
%>

转换乱玛,直接用xmlhttp调用有中文字符的网页得到的将是乱玛,可以通过adodb.stream组件进行转换

<%
Function BytesToBstr(body,Cset)
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 = Cset
BytesToBstr = objstream.ReadText
objstream.Close
set objstream = nothing
End Function
txtURL=server.MapPath("../index.asp")
sText = getHTTPPage(txtURL)
Set FileObject=Server.CreateObject("Scripting.FileSystemObject")
filename="../index.htm"
Set openFile=FileObject.OpenTextfile(server.mapPath(filename),2,true) ‘true为不存在自行建立
openFile.writeline(sText)
Set OpenFile=nothing
%>
<script>
alert("静态网页生成完毕");
history.back();
</script>

asp转HTML的类

<%
Class Htmlmaker

‘/*************************
‘/ 属性设置说明

‘/ foldename   "文件夹名"
‘/ 如果不设置,将自动生成[年月日]时间格式的文件夹名

‘/ Filename "文件名"(含前后缀)  
‘/ 如果不设置,将自动生成[时分秒]时间格式的文件名,后缀为.html

‘/ Htmlstr   "生成的代码内容"
‘/*************************

Private HtmlFolder,HtmlFilename,HtmlContent

Public property let foldename(str)
      HtmlFolder=str
End property

Public property let Filename(str)
      HtmlFilename=str
End property

Public property let Htmlstr(str)
      HtmlContent=str
End property

‘/*************************
‘/ 文件名转换日期函数
‘/*************************

Private Function Datename1(timestr)
   dim s_year,s_month,s_day
   s_year=year(timestr)
   if len(s_year)=2 then s_year="20"&s_year
   s_month=month(timestr)
   if s_month<10 then s_month="0"&s_month
   s_day=day(timestr)
   if s_day<10 then s_day="0"&s_day
   Datename1=s_year & s_month & s_day
End Function

Private Function Datename2(timestr)
   dim s_hour,s_minute,s_ss
   s_hour=hour(timestr)
   if s_hour<10 then s_hour="0"&s_hour
   s_minute=minute(timestr)
   if s_minute<10 then s_minute="0"&s_minute
   s_ss=second(timestr)
   if s_ss<10 then s_ss="0"&s_ss
   Datename2 = s_hour & s_minute & s_ss
End Function

‘/*************************
‘/ 初试化
‘/*************************

Private Sub class_initialize()
HtmlFolder=Datename1(now)
HtmlFilename=Datename2(now)&".html"
HtmlContent=""
End Sub
      
Private Sub class_terminate()
End Sub

‘/*************************
‘/ Html文件生成
‘/*************************

Public Sub Htmlmake()
On Error Resu
me Next
      dim filepath,fso,fout
      filepath = HtmlFolder&"/"&HtmlFilename
      Set fso = Server.CreateObject("Scripting.FileSystemObject")
            If fso.FolderExists(HtmlFolder) Then
            Else
            fso.CreateFolder(Server.MapPath(HtmlFolder))
            End If
      Set fout = fso.CreateTextFile(Server.MapPath(filepath),true)
      fout.WriteLine HtmlContent
      fout.close
End Sub

‘/*************************
‘/ Html文件删除
‘/*************************

Public Sub Htmldel()
      dim filepath,fso
      filepath = HtmlFolder&"/"&HtmlFilename
      Set fso = CreateObject("Scripting.FileSystemObject")
      fso.DeleteFile(Server.mappath(filepath))
      Set fso = nothing
End Sub

End class
%>