• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

asp磁盘缓存技术使用的代码

asp 搞代码 4年前 (2022-01-03) 31次浏览 已收录 0个评论

系统包括两个文件,其实可以合并为一个。之所以分为两个是因为部分杀毒软件会因为里边含有FSO、XMLHTTP操作而被认为是脚本木马

这一种方法适合,访问相对集中在同样内容页面的网站,会自动生成缓存文件(相当于读取静态页面,但会增大文件)。如果访问不集中会造成服务器同时读取文件当机。

注意:系统需要FSO权限、XMLHTTP权限

系统包括两个文件,其实可以合并为一个。之所以分为两个是因为部分杀毒软件会因为里边含有FSO、XMLHTTP操作而被认为是脚本木马。

调用时,需要在ASP页面的最上边包含主文件,然后在下边写下以下代码

 

代码如下:
主包含文件:FileCatch.asp

<%
‘—- 本文件用于签入原始文件,实现对页面的文件Catch
‘—- 1、如果文件请求为POST方式,则取消此功能
‘—- 2、文件的请求不能包含系统的识别关键字
‘—- 3、作者 何直群 (www.wozhai.com)
Class CatchFile
        Public Overdue,Mark,CFolder,CFile ‘定义系统参数
        Private ScriptName,ScriptPath,ServerHost ‘定义服务器/页面参数变量
        Public CatchData        ‘输出的数据

        Private Sub Class_Initialize        ‘初始化函数
                ‘获得服务器及脚本数据
                ScriptName=Request.Servervariables(“Script_Name”) ‘识别出当前脚本的虚拟地址
                ScriptPath=GetScriptPath(false)        ‘识别出脚本的完整GET地址
                ServerHost=Request.Servervariables(“Server_Name”) ‘识别出当前服务器的地址

                ‘初始化系统参数
                Overdue=30        ‘默认30分钟过期
                Mark=”NoCatch”        ‘无Catch请求参数为 NoCatch
                CFolder=GetCFolder        ‘定义默认的Catch文件保存目录
                CFile=Server.URLEncode(ScriptPath)&”.txt”        ‘将脚本路径转化为文件路径

                CatchData=””
        end Sub

        Private Function GetCFolder
                dim FSO,CFolder
                Set FSO=CreateObject(“Scripting.FileSystemObject”)        ‘设置FSO对象
                CFolder=Server.MapPath(“/”)&”/FileCatch/”
                if not FSO.FolderExists(CFolder) then
                        fso.CreateFolder(CFolder)
                end if
                if Month(Now())<10 then
                        CFolder=CFolder&”/0″&Month(Now())
                else
                        CFolder=CFolder&Month(Now())
                end if
                if Day(Now())<10 then
                        CFolder=CFolder&”0″&Day(Now())
                else
                        CFolder=CFolder&Day(Now())
                end if
                CFolder=CFolder&”/”
                if not FSO.FolderExists(CFolder) then
                        fso.CreateFolder(CFolder)
                end if
                GetCFolder=CFolder
                set fso=nothing
        End Function

        Private Function bytes2BSTR(vIn)        ‘转换编码的函数
                dim StrReturn,ThisCharCode,i,NextCharCode
                strReturn = “”
                For i = 1 To LenB(vIn)
                        ThisCharCode = AscB(MidB(vIn,i,1))
                        If ThisCharCode <&H80 Then
                                strReturn = strReturn & Chr(ThisCharCode)
                        Else
                                NextCharCode = AscB(MidB(vIn,i+1,1))
                                strReturn = strReturn & Chr(CLng(ThisCharCode) * &H100 + CInt(NextCharCode))
                                i = i + 1
                        End If
                Next
                bytes2BSTR = strReturn
        End Function

        Public Function CatchNow(Rev)        ‘用户指定开始处理Catch操作
                if UCase(request.Servervariables(“Request_Method”))=”POST” then
                ‘当是POST方法,不可使用文件Catch
      来源gao.dai.ma.com搞@代*码网                  Rev=”使用POST方法请求页面,不可以使用文件Catch功能”
                        CatchNow=false
                else
                        if request.Querystring(Mark)”” then
                        ‘如果指定参数不为空,表示请求不可以使用Catch
                                Rev=”请求拒绝使用Catch功能”
                                CatchNow=false
                        else
                                CatchNow=GetCatchData(Rev)
                        end if
                end if
        End Function

        Private Function GetCatchData(Rev)        ‘读取Catch数据
                Dim FSO,IsBuildCatch
                Set FSO=CreateObject(“Scripting.FileSystemObject”)        ‘设置FSO对象,访问CatchFile

                If FSO.FileExists(CFolder&CFile) Then
                        Dim File,LastCatch
                        Set File=FSO.GetFile(CFolder&CFile)        ‘定义CatchFile文件对象
                        LastCatch=CDate(File.DateLastModified)
                        if DateDiff(“n”,LastCatch,Now())>Overdue then
                        ‘如果超过了Catch时间
                                IsBuildCatch=true
                        else
                                IsBuildCatch=false
                        end if
                        Set File=Nothing
                else
                        IsBuildCatch=true
                End if

                If IsBuildCatch then
                        GetCatchData=BuildCatch(Rev)        ‘如果需要创建Catch,则创建Catch文件,同时设置Catch的数据
                else
                        GetCatchData=ReadCatch(Rev)        ‘如果不需要创建Catch,则直接读取Catch数据
                End if

                Set FSO=nothing
        End Function

        Private Function GetScriptPath(IsGet)        ‘创建一个包含所有请求数据的地址
                dim Key,Fir
                GetScriptPath=ScriptName
                Fir=true
                for Each key in Request.QueryString
                        If Fir then
                                GetScriptPath=GetScriptPath&”?”
                                Fir=false
                        else
                                GetScriptPath=GetScriptPath&”&”
                        end if
                        GetScriptPath=GetScriptPath&Server.URLEncode(Key)&”=”&Server.URLEncode(Request.QueryString(Key))
                Next
                if IsGet then
                        If Fir then
                                GetScriptPath=GetScriptPath&”?”
                                Fir=false
                        else
                                GetScriptPath=GetScriptPath&”&”
                        end if
                        GetScriptPath=GetScriptPath&Server.URLEncode(Mark)&”=yes”
                end if
        End Function

        ‘创建Catch文件
        Private Function BuildCatch(Rev)
                Dim HTTP,Url,OutCome
                Set HTTP=CreateObject(“Microsoft.XMLHTTP”)
‘                On Error Resume Next
‘                response.write ServerHost&GetScriptPath(true)
                HTTP.Open “get”,”http://”&ServerHost&GetScriptPath(true),False
                HTTP.Send

                if Err.number=0 then
                        CatchData=bytes2BSTR(HTTP.responseBody)
                        BuildCatch=True
                else
                        Rev=”创建发生错误:”&Err.Description
                        BuildCatch=False
                        Err.clear
                end if

                Call WriteCatch

                set HTTP=nothing
        End Function

        Private Function ReadCatch(Rev)
                ReadCatch=IReadCatch(CFolder&CFile,CatchData,Rev)
        End Function

        Private Sub WriteCatch
                Dim FSO,TSO
                Set FSO=CreateObject(“Scripting.FileSystemObject”)        ‘设置FSO对象,访问CatchFile
                set TSO=FSO.CreateTextFile(CFolder&CFile,true)
                TSO.Write(CatchData)
                Set TSO=Nothing
                Set FSO=Nothing
        End Sub
End Class
%>  

以上就是asp磁盘缓存技术使用的代码的详细内容,更多请关注gaodaima搞代码网其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:asp磁盘缓存技术使用的代码

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址