1. 论坛系统升级为Xenforo,欢迎大家测试!
    排除公告

asp生成静态页面的两种方法

本帖由 y58y182009-10-06 发布。版面名称:源码讨论

  1. y58y18

    y58y18 New Member

    注册:
    2009-09-29
    帖子:
    6
    赞:
    0
    为什么要生成静态首页?
    1、如果你首页读取的数据库次数比较多,速度很慢,而且占用很多服务器资源。使用静态页面访问速度当然快多了。
    2、搜索引擎容易搜索到。
    3、如果程序出问题,也能保证首页能访问。
    4、其他的太多,自己想:)
    应用方式:
    如果你的首页是index.asp,你可以生成index.htm (默认访问顺序必须是index.htm,index.asp)。这样访问者第一次访问到你的网站的时候打开的是index.htm。你可以把网站首页的链接做成index.asp,这样从网站任何一个页面点击首页的链接出现的就是index.asp,这样保证的信息更新的及时性(毕竟index.htm需要每次手动更新)。

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

    方法一:直接将首页文件包含在表单文本框中,将首页代码作为数据提交,然后生成静态页面。代码如下:
    <%
    '------------------------------------------------------------
    '使用表单提交生成静态首页的代码
    '确保你的空间支持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">
    <!--#include file="index.asp"-->
    </textarea>
    <br>
    <input type="submit" name="Submit" value="提交">
    </form>


    缺点:
    1、如果首页中包括<@&nbs3CBR>read=getHTTPPage(Curl)
    if read<>"" then
    content=read
    call makeindex()
    end if
    sub B1淼ナ莩ざ扔幸欢ǖ南拗疲?BR>
    解决方案:
    1、去掉index.asp中的<@ >标记
    2、使用eWebEditor,提交支持大数据(能自动分割)

    优点:
    可以在生成时对内容实时修窩ι墒滓常?)</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
    g码如下:
    <%
    '------------------------------------------------------------
    '作者: kevin fung,落伍者ID:kevin2008
    '------------------------------------------------------------
    Dim 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
    objstreamC4件将以字符串读入该变量
    Dim content'替换后的字符串变量
    Dim Conn'连接对象
    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 star是榭鲂薷模绻吡耍锹技芏嗟氖焙蚧岢鱿殖贝砦?BR>content = Replace(Template,"{filed_name_1}",rs("filed_name_1"))'用字段值替换模板内容
    content = Replace(content,"{filed_name_2}",rs("filed_name_2"))&start'该变量为指针将要指向的记录集位置,通过参数动态获得
    Dim Template'模板文件将以字符串读入该变量
    Dim content'替换后的字符串变量
    Dim Conn'连接对象
    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 Conn = Server.CreateObject("ADODB.Connection")
    Conn.Open ConnStr

    set rs = Server.CreateObject("ADODB.Recordset")
    rs.open sql,Conn,1,1'打开数総h("htmfiles/"&rs("id")&".html")'将替换之后的Template字符串生成HTML文档,htmfiles为存储静态文件的目录,请手动建立

    cnt = cnt + 1 '计数器加1
    start = start + 1 '指针变量递增
    rs.movenexname为生成的文件名
    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
    %>


    ASP静态化后,静态html页面点击计数解决方法:nbsp;
    '......'
    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
    Conn.Close()
    Set Conn = 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
    %>

    ASP静态化后,静态html页面点击计数解决方法:

    实现方法很简单,通过在html页面放置代码<script type="text/javascript" src="计数器.asp"></script>即可,具体如下:

    假设有个news的表,有一字段id,每一条新闻对应1个id。另有一个hit字段,用来统计被点次数。

    1、在你要统计点击次数的html页面,加入以下代码(这里count.asp与本文件同目录):
    <script type="text/javascript" src="count.asp?id=新闻相应的IP"></script>


    说明:这里如果你是从ASP静态化成HTML的,那么新闻相应的IP可以通过调动数据库自动填写,很方便。

    2、将下面的代码保存成count.asp
    <%ConnStr = "Provider = Microsoft.Jet.OLEDB.4.0;Data Source = " & Server.MapPath("DataBase.mdb")
    Set Conn = Server.CreateObject("ADODB.Connection")
    Conn.Open ConnStr%>
    totalhits=0
    <%
    sql="select * from news where id="&request.querystring("id")'按get来的id搜索相应记录
    set rst=server.CreateObject("adodb.recordset")
    rst.open sql,conn,1,3
    rst("hit")=rst("hit")+1
    rst.update
    %>
    totalhits=<%=rst("hit")%>
    <%rst.close
    set rst=nothing
    %>
    document.write(totalhits)


    本站静态化后,就是通过这样实现点击统计。