成人视屏在线观看-国产99精品-国产精品1区2区-欧美一级在线观看-国产一区二区日韩-色九九九

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

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

瀏覽:130日期: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久女女精品视频在线观看 | 国产男女交性视频播放免费bd | 热99re久久精品这里都是免费 | 黑人巨大交牲老太 | 日本加勒比高清一本大道 | 国产免费人视频在线观看免费 | 久久不见久久见免费影院www日本 | 日韩精品综合 | avove旗袍丝袜高跟啪啪 | 亚洲成人7777| 国产一在线精品一区在线观看 | 国产精品区牛牛影院 | 天堂男人2021av| 免费看裸色 | 久久高清一区二区三区 | 高h原耽肉汁动漫视频 | 成人综合网址 | 人成午夜性刺激免费 | 国产精品爽爽va在线观看无码 | 日本特黄乱人伦片 | 亚洲高清视频免费 | 亚洲欧美一区二区三区四区 | 国产成人精品日本亚洲专区6 | 在线播放国产一区二区三区 | www.欧美在线观看 | 国产亚洲精品aaa大片 | 欧美人成毛片在线播放 | 精品日韩欧美 | 久久精品视频免费在线观看 | 久久成人18| 真人一级毛片全部免 | 成人深夜福利在线播放不卡 | 鲁老汉精品视频在线观看 | 一级毛片播放 | 日本午夜高清视频 | 99亚洲自拍 | 亚洲第四页 | 日本韩国台湾香港三级 | free性欧美嫩交 | 精品一区二区久久久久久久网站 |