加入收藏 | 设为首页 | 会员中心 | 我要投稿 聊城站长网 (https://www.0635zz.com/)- 智能语音交互、行业智能、AI应用、云计算、5G!
当前位置: 首页 > 站长学院 > Asp教程 > 正文

用多个方法实现 ASP页面静态化和 Script分享

发布时间:2023-06-19 14:28:49 所属栏目:Asp教程 来源:
导读:最近朋友网站需要将网站生成静态,但有时候生成静态会出现问题,特多整理了一些方法, 大家可以根据自己网站需要选择。

1、ASP两种简单的生成静态首页的方法

为什么要生成静态首页?

1、如果你首页读取的
最近朋友网站需要将网站生成静态,但有时候生成静态会出现问题,特多整理了一些方法, 大家可以根据自己网站需要选择。

1、ASP两种简单的生成静态首页的方法
 
为什么要生成静态首页?
 
1、如果你首页读取的数据库次数比较多,速度很慢,而且占用很多服务器资源。使用静态页面访问速度当然快多了
 
2、搜索引擎容易搜索到
 
3、如果程序出问题,也能保证首页能访问。
 
4、其他的太多,自己想:)
 
应用方式:
 
如果你的首页是index.asp,你可以生成index.htm (默认访问顺序必须是index.htm,index.asp)。这样访问者第一次访问到你的网站的时候打开的是index.htm 。你可以把网站首页的链接做成index.asp,这样从网站任何一个页面点击首页的链接出现的就是index.asp,这样保证的信息更新的及时性(毕竟index.htm需要每次手动更新)。
 
方法一:
 
直接将首页文件包含在表单文本框中,将首页代码最为数据提交,然后生成静态页面。
 
代码如下:
 
复制代码代码如下:
 
<%
 
'------------------------------------------------------------
 
'使用表单提交生成静态首页的代码
 
'确保你的空间支持FSO,且首页代码内容较少
 
'------------------------------------------------------------
 
dim content
 
content=Trim(Request.Form("content"))
 
if content<>"" then
 
call makeindex()
 
end if
 
sub makeindex()
 
Set Fso = Server.CreateObject("Scripting.FileSystemObject")
 
Filen=Server.MapPath("index.htm")
 
Set Site_Config=FSO.CreateTextFile(Filen,true, False)
 
Site_Config.Write content
 
Site_Config.Close
 
Set Fso = Nothing
 
Response.Write("<script>alert('已经成功生成首页!')</script>")
 
end sub
 
%>
 
<form name="form1" method="post" action="">
 
<textarea name="content">
 
<!-- #i nclude file="index.asp" -->
 
</textarea>
 
<br>
 
<input type="submit" name="Submit" value="提交">
 
</form>
 
缺点:
 
1、如果首页中包括<@ ..>标记,会提示出错。
 
2、如果首页代码较长,用表单无法提交过去(表单数据长度有一定的限制)。
 
解决方案:
 
1、去掉index.asp中的<@ >标记
 
2、使用eWebEditor,提交支持大数据(能自动分割)
 
优点:
 
可以在生成时对内容实时修改。
 
方法二:
 
直接使用XMLHTTP获取index.asp的代码
 
复制代码代码如下:
 
<%
 
'----------------------------------------------------------
 
'使用XMLHTTP生成静态首页的代码
 
'Curl 为你的首页地址,确保你的空间支持FSO
 
'-----------------------------------------------------------
 
dim read,Curl,content
 
Curl="http://www.xx0123.com/index.asp"
 
read=getHTTPPage(Curl)
 
if read<>"" then
 
content=read
 
call makeindex()
 
end if
 
sub makeindex()
 
Set Fso = Server.CreateObject("Scripting.FileSystemObject")
 
Filen=Server.MapPath("index.htm")
 
Set Site_Config=FSO.CreateTextFile(Filen,true, False)
 
Site_Config.Write content
 
Site_Config.Close
 
Set Fso = Nothing
 
Response.Write("<script>alert('已经成功生成首页!')</script>")
 
end sub
 
Function getHTTPPage(url)
 
dim http
 
set http=Server.createobject("Microsoft.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
 
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
 
%>
 
 
2、模板分离批量生成
 
模板文件中要替换的内容均以{...}括起来
 
为力求简洁,去掉了错误处理代码(replace中要来替换的字符串参数不能为null值,当然fso也应该做错误检查)。
 
复制代码代码如下:
 
<%
 
' ---------------------------------------------------------------------------------------------------------------------
 
' 出自: kevin fung http://www.yaotong.cn
 
' 作者: kevin fung 落伍者ID:kevin2008,转载时请保持原样
 
' 时间: 2006/07/05落伍者论坛首发
 
' ----------------------------------------------------------------------------------------------------------------------
 
Dim start '该变量为指针将要指向的记录集位置,通过参数动态获得
 
Dim Template '模板文件将以字符串读入该变量
 
Dim content '替换后的字符串变量
 
Dim objConn '连接对象
 
Dim ConnStr '连接字符串
 
Dim sql '查询语句
 
Dim cnt:cnt = 1 '本轮循环计数器初始化
 
start = request("start") '获取本轮指针的开始位置
 
If IsNumeric(start) Then start = CLng(start) Else start=1
 
If start=0 Then start = 1 '如果start
 
ConnStr = "Provider = Microsoft.Jet.OLEDB.4.0;Data Source = " & Server.MapPath("DataBase.mdb")
 
sql = "select * from table_name"
 
Set objConn = Server.CreateObject("ADODB.Connection")
 
objConn.Open ConnStr
 
set rs = Server.CreateObject("ADODB.Recordset")
 
rs.open sql,objConn,1,1 '打开数据集
 
rs.AbsolutePosition = start '最关键的一步,将指针指向start,start通过参数动态获得
 
Template = getTemplate(Server.MapPath("template.html"))' template.html为模板文件,通过函数getTemplate读入到字符串,模板文件中要替换的内容均以{...}括起来
 
While Not rs.eof And cnt<= 500 '500是设定一次请求生成页面的循环次数,根据实际情况修改,如果太高了,记录集很多的时候会出现超时错误
 
content = Replace(Template,"{filed_name_1}",rs("filed_name_1")) '用字段值替换模板内容
 
content = Replace(content,"{filed_name_2}",rs("filed_name_2"))
 
......
 
content = Replace(content,"{filed_name_n}",rs("filed_name_n"))
 
genHtml content,Server.MapPath("htmfiles/"&rs("id")&".html") '将替换之后的Template字符串生成HTML文档,htmfiles为存储静态文件的目录,请手动建立
 
cnt = cnt + 1 '计数器加1
 
start = start + 1 '指针变量递增
 
rs.movenext
 
wend
 
If Not rs.eof Then '通过刷新的方式进行下一轮请求,并将指针变量start传递到下一轮
 
response.write "<meta http-equiv='refresh' content='0;URL=?start="&start&"'>"
 
Else
 
response.write "生成HTML文件完毕!"
 
End if
 
rs.Close()
 
Set rs = Nothing
 
objConn.Close()
 
Set objConn = Nothing
 
Function getTemplate(template)'读取模板的函数,返回字符串,template为文件名
 
Dim fso,f
 
set fso=CreateObject("Scripting.FileSystemObject")
 
set f = fso.OpenTextFile(template)
 
getTemplate=f.ReadAll
 
f.close
 
set f=nothing
 
set fso=Nothing
 
End Function
 
Sub genHtml(content,filename)'将替换后的内容写入HTML文档,content为替换后的字符串,filename为生成的文件名
 
Dim fso,f
 
Set fso = Server.CreateObject("Scripting.FileSystemObject")
 
Set f = fso.CreateTextFile(filename,true)'如果文件名重复将覆盖旧文件
 
f.Write content
 
f.Close
 
Set f = Nothing
 
set fso=Nothing
 
End Sub
 
%>
 
 

(编辑:聊城站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章