UBB 转换函数演示 (经典论坛)(5)

re.pattern="\[code\](\r\n)?([\s\S]+?)\[\/code\]"
Set Matches = re.Execute(content)   ' Execute search.
dim code()
n=0
if re.test(content) then codeb=true
if codeb then
  For Each Match in Matches      ' Iterate Matches collection.
   redim Preserve code(n)
    code(n) =Match.Value
    n=n+1
  Next
for i=0 to ubound(code)
if code(i)="" then exit for
content=replace(content,code(i),"{code"&i&"}")
next
end if


re.pattern="\[html\](\r\n)?([\s\S]+?)\[\/html\]"
Set Matches = re.Execute(content)   ' Execute search.
dim html()
n=0
if re.test(content) then htmlb=true
if htmlb then
  For Each Match in Matches      ' Iterate Matches collection.
   redim Preserve html(n)
    html(n) =Match.Value
n=n+1
  Next
for i=0 to ubound(html)
if html(i)="" then exit for
content=replace(content,html(i),"{html"&i&"}")
next
end if

content=gmt(content)    'ubb


if codeb then
for i=0 to ubound(code)
if code(i)="" then exit for
tcode=hencode(code(i))
content=replace(content,"{code"&i&"}",tcode)
next
end if
'-----
re.pattern="\[html\](\r\n)?([\s\S]+?)\[\/html\]"
Set Matches = re.Execute(content)   ' Execute search.
dim html2()
n=0
if re.test(content) then html2b=true
if html2b then
  For Each Match in Matches      ' Iterate Matches collection.
   redim Preserve html2(n)
    html2(n) =Match.Value
n=n+1
  Next
for i=0 to ubound(html2)
if html2(i)="" then exit for
content=replace(content,html2(i),"{html2"&i&"}")
next
end if


if htmlb then
for i=0 to ubound(html)
if html(i)="" then exit for
thtml=hencode(html(i))
content=replace(content,"{html"&i&"}",thtml)
next
end if

re.Pattern="(\[code\])(\r\n)?([\s\S]+?)(\[\/code\])"
content=re.Replace(content,"<PRE class=CodeSamp>$3</PRE>")

re.Pattern="(\[html\])(\r\n)?([\s\S]+?)(\[\/html\])"
content=re.Replace(content,"<span><TEXTAREA cols=95 rows=12>$3</TEXTAREA><br><INPUT onclick=runCode() type=button value=运行代码>[Ctrl+A 全部选择 提示:你可先修改部分代码,再按运行]</span>")

if html2b then
for i=0 to ubound(html2)
if html2(i)="" then exit for
thtml2=html2(i)
content=replace(content,"{html2"&i&"}",thtml2)
next
end if

UBBCode=content
msgbox "转换共耗时 "&formatnumber((timer-st)*1000,2)&" ms"
end function

function hencode(fString)  '简单模拟server.htmlencode   ASP中不用这个
 fString = replace(fString,"&","&amp;")
 fString = replace(fString,">","&gt;") 
 fString = replace(fString,"<","&lt;") 
hencode=fString
end function

function DvbbsHtmlAn(fString)

if not isnull(fString) then

fString=hencode(fString)
 fString = Replace(fString, CHR(9), "&nbsp;&nbsp;&nbsp;") 'Tab
 fString = Replace(fString, CHR(34), "&quot;")   '"
 fString = Replace(fString, CHR(39), "&#39;")   ''
 fString = Replace(fString, CHR(13), "")    '回车是一个13+10
 fString = Replace(fString, CHR(10) & CHR(10), "<P>")'  '
 fString = Replace(fString, CHR(10), "<BR>")
 fString = Replace(fString, CHR(32), "&nbsp;")   ' 空格

 DvbbsHtmlAn = fString
end if
end function

function gmt(strContent)

strContent=DvbbsHtmlAn(strContent)

 dim re
 Set re=new RegExp
 re.IgnoreCase =true
 re.Global=True

re.Pattern="(\[IMG\])(.*?)(\[\/IMG\])"
 strContent=re.Replace(strContent,"<a href=https://www.jb51.net/article/$2 target=_blank><IMG SRC=""https://www.jb51.net/article/$2"" border=0 alt=按此在新窗口浏览图片javascript:if(this.width>screen.width-333)this.width=screen.width-333"" galleryImg=no></a>")

if Not UserSign or (UserSign and UserImgCode=1) then
 re.Pattern="\[DIR=*([0-9]*),*([0-9]*)\](.*?)\[\/DIR]"
 strContent=re.Replace(strContent,"<object classid=clsid:166B1BCA-3F9C-11CF-8075-444553540000 codebase=http://download.macromedia.com/pub/shockwave/cabs/director/sw.cab#version=7,0,2,0 width=https://www.jb51.net/article/$1 height=https://www.jb51.net/article/$2><param name=src value=https://www.jb51.net/article/$3><embed src=https://www.jb51.net/article/$3 pluginspage=http://www.macromedia.com/shockwave/download/ width=https://www.jb51.net/article/$1 height=https://www.jb51.net/article/$2></embed></object>")
 re.Pattern="\[QT=*([0-9]*),*([0-9]*)\](.*?)\[\/QT]"
 strContent=re.Replace(strContent,"<embed src=https://www.jb51.net/article/$3 width=https://www.jb51.net/article/$1 height=https://www.jb51.net/article/$2 autoplay=true loop=false controller=true playeveryframe=false cache=false scale=TOFIT bgcolor=#000000 kioskmode=false targetcache=false pluginspage=http://www.apple.com/quicktime/>")
 re.Pattern="\[MP=*([0-9]*),*([0-9]*)\](.*?)\[\/MP]"
 strContent=re.Replace(strContent,"<object align=middle classid=CLSID:22d6f312-b0f6-11d0-94ab-0080c74c7e95 class=OBJECT id=MediaPlayer width=https://www.jb51.net/article/$1 height=https://www.jb51.net/article/$2 ><param name=ShowStatusBar value=-1><param name=Filename value=https://www.jb51.net/article/$3><embed type=application/x-oleobject codebase=http://activex.microsoft.com/activex/controls/mplayer/en/nsmp2inf.cab#Version=5,1,52,701 flename=mp src=https://www.jb51.net/article/$3  width=https://www.jb51.net/article/$1 height=https://www.jb51.net/article/$2></embed></object>")
 re.Pattern="\[RM=*([0-9]*),*([0-9]*)\](.*?)\[\/RM]"
 strContent=re.Replace(strContent,"<OBJECT classid=clsid:CFCDAA03-8BE4-11cf-B84B-0020AFBBCCFA class=OBJECT id=RAOCX width=https://www.jb51.net/article/$1 height=https://www.jb51.net/article/$2><PARAM NAME=SRC VALUE=https://www.jb51.net/article/$3><PARAM NAME=CONSOLE VALUE=Clip1><PARAM NAME=CONTROLS VALUE=imagewindow><PARAM NAME=AUTOSTART VALUE=true></OBJECT><br><OBJECT classid=CLSID:CFCDAA03-8BE4-11CF-B84B-0020AFBBCCFA height=32 id=video2 width=https://www.jb51.net/article/$1><PARAM NAME=SRC VALUE=https://www.jb51.net/article/$3><PARAM NAME=AUTOSTART VALUE=-1><PARAM NAME=CONTROLS VALUE=controlpanel><PARAM NAME=CONSOLE VALUE=Clip1></OBJECT>")
 end if

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/wfzzgd.html