精灵王
- 注册日期2010-12-08
- 发帖数640
- QQ
- 火币1103枚
- 粉丝120
- 关注75
|
阅读:3554回复:0
对asp动态包含文件方法的改进_asp技巧
楼主#
更多
发布于:2010-12-26 16:01
| | | | ASP 本身不支持动态包含文件,目前的动态包含是通过 FSO 把被包含的文件合并到主文件里再运行。以下也有把形如 的普通包含文件方式称作“传统引用”,用函数实现的动态包含文件称作“动态引用”。常见的程式如下:Function include(filename) Dim re,content,fso,f,aspStart,aspEndset fso=CreateObject("Scripting.FileSystemObject") set f=fso.OpenTextFile(server.mappath(filename)) content=f.ReadAll f.close set f=nothing set fso=nothingset re=new RegExp re.pattern="^\s*=" aspEnd=1 aspStart=inStr(aspEnd,content,"<%")+2 do while aspStart>aspEnd+1 Response.write Mid(content,aspEnd,aspStart-aspEnd-2) aspEnd=inStr(aspStart,content,"%\>")+2 Execute(re.replace(Mid(content,aspStart,aspEnd-aspStart-2),"Response.Write ")) aspStart=inStr(aspEnd,content,"<%")+2 loop Response.write Mid(content,aspEnd) set re=nothing End Function 使用范例:include("youinc.asp") 但这处函数在处理补包含的文件中更有包含文件时就不灵了。我在以上函数的基础上改进出来如下函数,在被包含文件中更有普通的包含文件 也可正常运行。Function includeconvert(oRegExp, strFilename, strBlock) Dim incStart, incEnd, match, oMatches, str, code 用提取ASP代码的相同方式提取出include 部分的文件名,其余部分原样输出 code = "" incEnd = 1 incStart = InStr(incEnd,strBlock,"Do While incStart>incEnd+12 两个引用间距最小就是连续的--><--#,incStart是从incEnd+12的条件 str = Mid(strBlock,incEnd,incStart-incEnd-13) str = Replace(str, """", """""") 把单个双引号换成两个双引号 str = Replace(str, VbCr, "") str = Replace(str, VbLf, "") str = Replace(str, VbCrLf, "") code = code ; VbCrLf ; "Response.Write """ ; str ; """" incEnd=InStr(incStart,strBlock,"-->")+3 oRegExp.pattern="(\w+)=""([^""]+)""" 匹配 file="filename.ext" 或 virtual="virtualname.ext",捕捉类型及文件名两个子串 Set oMatches = oRegExp.Execute(Mid(strBlock,incStart,incEnd-incStart-3)) Set match = oMatches(0) 确定只有一组捕捉时,要得到这一组匹配的子串,能这样做,省去用 For Each match In oMatches …… Next code = code ; include(Mid(strFilename, 1, InStrRev(strFilename, "/")) ; match.SubMatches(1)) Mid(filename, 1, InStrRev(filename, "/")) 是在被引用的子文件名有路径时,把路径提取出来,加在子文件中传统引用的文件名前面,以找到正确的打开文件路径,因为动态引用时的文件路径是相对主文件而言的。要第二个匹配子串用SubMatches(1) incStart = InStr(incEnd,strBlock,"Loop str = Mid(strBlock,incEnd) str = Replace(str, """", """""") 把单个双引号换成两个双引号 str = Replace(str, VbCr, "") str = Replace(str, VbLf, "") str = Replace(str, VbCrLf, "") code = code ; VbCrLf ; "Response.Write """ ; str ; """" includeconvert = code End Function Function include(filename) Dim re, content, fso, f, aspStart, aspEnd, code Set fso=CreateObject("scripting.FileSystemObject") Set f=fso.OpenTextFile(Server.MapPath(filename)) content=f.ReadAll f.close Set f=nothing Set fso=nothing code = "" aspEnd=1 aspStart=InStr(aspEnd,content,"aspEnd+1 传统引用code = code ; includeconvert (re, filename, Mid(content,aspEnd,aspStart-aspEnd-2)) aspEnd=InStr(aspStart,content,"%\>")+2 re.pattern="^\s*=" 这段正则替换原来是把 换回成标准的 code = code ; VbCrLf ; re.replace(Mid(content,aspStart,aspEnd-aspStart-2),"Response.Write ") ASP块前面再加回车换行,以避免连接块之间多个 Response.Write在同一行的错误 aspStart=InStr(aspEnd,content," 以上内容由 华夏名网 搜集整理,如转载请注明原文出处,并保留这一部分内容。 华夏名网网址导航: 虚拟主机 双线主机 主机 域名注册 cn域名 域名 服务器租用 酷睿服务器 vps vps主机 (阅读次数:499)上一篇:asp调用带参数存储过程的几种方式_asp技巧 下一篇: 整站二进制数据库文件还原_asp技巧[收藏] [推荐] [评论] [打印本页] [返回上一页][关闭窗口] 昵称: (为空则显示guest) 评论分数: ★ ★ ★ ★★★ ★★★★ ★★★★★ 评论内容:(不能超过250字,需审核后才会公布,请自觉遵守互联网相关政策法规。
| | | | |
|