av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁技術文章
文章詳情頁

one.asp多項目、函數庫、類庫 統一為一個版本的方法

瀏覽:109日期:2022-06-04 17:56:51

前幾天 寫的博客 多項目 函數庫、類庫 統一為一個版本的方法中提到 使用 one.php 將整個項目打包成 一個 php 文件,有網友 讓我 整個asp版本的,今天下午抽空寫了個 one.asp,使用方式基本一致,這次 增加了路徑計算的功能,可以引用不同路徑。

舉個簡單的應用場景,開發一個小的API系統,支持 XML、JSON輸出。區別是 基礎版(dev/dev.asp)只支持 Access,VIP版本(dev/vip.asp)支持 Access + SQL Server。這樣VIP版本就需要在現在的基礎上 增加 sqlserver的支持,增加額外的 配置項。開發過程只需要 按正常開發即可。

開發完畢后,通過 one.asp 打包成 index.asp 和 vip.asp 兩個版本,整套程序都是一個獨立的文件。

下圖演示了 解析過程:

完整的測試代碼 可以 訪問:oneasp.rar 下載

核心代碼 如下:

" ====================================================
" 類名:One
" 作者:mqycn
" 博客:http://www.miaoqiyuan.cn
" 源碼:http://www.miaoqiyuan.cn/p/one-php
" 說明:多項目 函數庫、類庫 統一為一個版本的方法
" ====================================================
Class OneAsp
  Private FSO
  Private Root
   
  Private Sub Class_Initialize()
    Set FSO = Server.CreateObject("Scripting.FileSystemObject")
  End Sub
   
  Private Sub Class_Terminate()
    Set FSO = Nothing
  End Sub
   
  Public Function Run(ByVal sourceFile, ByVal saveFile)
    Run = "<hr><b>Input:</b>" & sourceFile & "<br><b>Result:</b>" & Save(saveFile, Include(sourceFile))
  End Function
   
   
  Public Function Include(ByVal path)
    Dim tmpPath, tmpItem, arrPath, index
    tmpPath = ""
    arrPath = Split(path, "/")
    For index = 0 To UBound(arrPath) - 1
      tmpItem = arrPath(index)
      tmpPath = tmpPath & tmpItem & "/"
    Next
    Include = Parse(tmpPath, arrPath(UBound(arrPath)))
  End Function
   
  Private Function Parse(ByVal root, ByVal fileName)
    Call SetRoot(root)
    Dim html
    html = OpenRead(fileName)
     
    Dim preg, pregResult
    Set preg = New Regexp
    preg.pattern = "<!--#include file=""([^""]*)""-->"
    preg.global = True
    preg.ignorecase = True
     
    Dim htmlInclude
    Set pregResult = preg.execute(html)
    For Each htmlInclude In pregResult
      html = Replace(html, htmlInclude, Include(root & htmlInclude.submatches(0)))
    Next
     
    Parse = "<% "" & root & fileName & " Start %" & ">" & vbCrLf & html & vbCrLf & "<%  "" & root & fileName & " End %" & ">" & vbCrLf
  End Function
   
  Private Function SetRoot(ByVal rootPath)
    If Right(rootPath, 1) <> "/" Then rootPath = rootPath & "/"
    Root = rootPath
  End Function
   
  Private Function RealPath(ByVal path)
    RealPath = Server.Mappath(Root & path)
  End Function
   
  Private Function OpenRead(ByVal path)
    Dim txtFile
    Set txtFile = FSO.OpenTextFile(RealPath(path))
    OpenRead = txtFile.ReadAll()
    txtFile.close
    On Error GoTo 0
  End Function
   
  Public Function Save(ByVal path, ByVal body)
    Dim txtFile
    Set txtFile = FSO.CreateTextFile(Server.Mappath(path))
    txtFile.write body
    txtFile.close
    Set txtFile = Nothing
    Save = path
  End Function
   
End Class

使用也非常簡單,使用 Call new OneAsp.run(開發版, 打包版),可以 dev.asp 中的所有包含的代碼 打包到 index.asp,如果只想獲取解析的內容,可以使用 Response.Write Server.Htmlencode(Call new OneAsp.include(開發版))

標簽: ASP
相關文章:
主站蜘蛛池模板: 超碰在线影院 | 久久在视频 | 欧美一区二区在线观看 | 国产精品女人久久久 | 欧美中文字幕一区 | 在线视频99| 亚洲午夜精品视频 | 噜噜噜噜狠狠狠7777视频 | 在线播放中文字幕 | 一区二区三区视频免费看 | 亚洲欧洲一区二区 | 亚洲福利av | 精品国产乱码久久久久久闺蜜 | 亚洲高清电影 | 亚洲精品在线国产 | 久久久99精品免费观看 | 羞羞视频在线观免费观看 | 九九亚洲| 在线a视频网站 | 中文字幕av网站 | 女朋友的闺蜜3韩国三级 | 久久精品色欧美aⅴ一区二区 | 日韩中文一区 | 中文一区二区视频 | 亚洲精品1 | 日韩在线一区二区 | 欧美成人免费在线视频 | 欧美日韩在线一区二区 | 亚洲精品电影网在线观看 | 国产一区二区久久 | 伊人网99 | 精品国产一区二区在线 | 久久99精品久久久久久狂牛 | 韩日av片 | 免费国产一区 | 国产精品成人一区二区 | av手机免费在线观看 | 久久久精品久久 | 天天夜碰日日摸日日澡 | 免费av在线网站 | 欧美成人一区二免费视频软件 |