asp网页生成静态htm文件的方法
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$为内容
<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组件进行转换
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 
%>

 
								 
								 
								 
								 
					 
								
发表评论