www.gusucode.com > 共享世纪内容管理系统 2.1 build 080704 全站开源版 > admin/inc/ubbcode.asp
<% rem ------------ubb代码 function ChkBadWords(fString) bwords = split(BadWords, "|") for i = 0 to ubound(bwords) fString = Replace(fString, bwords(i), string(len(bwords(i)),"*")) next ChkBadWords = fString end function function HTMLEncode(fString) if not isnull(fString) then fString = replace(fString, ">", ">") fString = replace(fString, "<", "<") fString = Replace(fString, CHR(32)&CHR(32), " ") fString = Replace(fString, CHR(34), """) fString = Replace(fString, CHR(39), "'") fString = Replace(fString, CHR(13), "") ' fString = Replace(fString, CHR(10) & CHR(10), "</P><P> ") fString = Replace(fString, CHR(10), "<BR> ") HTMLEncode = fString end if end function '以下Html转化可用 function HTMLEncode2(fString) fString = Replace(fString, CHR(32)&CHR(32)&CHR(32), " ") fString = Replace(fString, CHR(13), "") 'fString = Replace(fString, CHR(10), "<br>") fString = Replace(fString, CHR(10)& CHR(10), "<br>") HTMLEncode2 = fString end function function HTMLDecode(fString) fString = replace(fString, ">", ">") fString = replace(fString, "<", "<") fString = Replace(fString, " ", CHR(32)&CHR(32)&CHR(32)) fString = Replace(fString, "</P><P>", CHR(10) & CHR(10)) fString = Replace(fString, "<BR>", CHR(10)) fString = Replace(fString, "<br>", CHR(10)) fString = Replace(fString, " ", "CHR(32)") fString = Replace(fString, " ", " ") HTMLDecode = fString end function function UBBCode(strContent) ' if strAllowHTML <> 1 then strContent = HTMLEncode(strContent) ' end if dim re Set re=new RegExp re.IgnoreCase =true re.Global=True ' re.Pattern="(script)" ' strContent=re.Replace(strContent,"script") ' if strIMGInPosts = "1" then re.Pattern="(\[IMG\])(.[^\[]*)(\[\/IMG\])" strContent=re.Replace(strContent,"<a href=""$2"" target=_blank><IMG align=left SRC=""$2"" border=0 alt=按此在新窗口浏览图片 onload='javascript:if(this.width>screen.width-300)this.width=screen.width-300'></a>") ' end if 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=$1 height=$2><param name=src value=$3><embed src=$3 pluginspage=http://www.macromedia.com/shockwave/download/ width=$1 height=$2></embed></object>") re.Pattern="\[QT=*([0-9]*),*([0-9]*)\](.[^\[]*)\[\/QT]" strContent=re.Replace(strContent,"<embed src=$3 width=$1 height=$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=$1 height=$2 ><param name=ShowStatusBar value=-1><param name=Filename value=$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=$3 width=$1 height=$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=$1 height=$2><PARAM NAME=SRC VALUE=$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=$1><PARAM NAME=SRC VALUE=$3><PARAM NAME=AUTOSTART VALUE=-1><PARAM NAME=CONTROLS VALUE=controlpanel><PARAM NAME=CONSOLE VALUE=Clip1></OBJECT>") ' if strflash= "1" then re.Pattern="(\[FLASH\])(.[^\[]*)(\[\/FLASH\])" strContent= re.Replace(strContent,"<OBJECT codeBase=http://download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=4,0,2,0 classid=clsid:D27CDB6E-AE6D-11cf-96B8-444553540000 width=500 height=400><PARAM NAME=movie VALUE=""$2""><PARAM NAME=quality VALUE=high><embed src=""$2"" quality=high pluginspage='http://www.macromedia.com/shockwave/download/index.cgi?P1_Prod_Version=ShockwaveFlash' type='application/x-shockwave-flash' width=500 height=400>$2</embed></OBJECT>") 'end if re.Pattern="(\[ZIP\])(.[^\[]*)(\[\/ZIP\])" strContent=re.Replace(strContent,"<br><IMG SRC=../images/zip.gif border=0> <a href=""$2"">点击下载该文件</a>") re.Pattern="(\[RAR\])(.[^\[]*)(\[\/RAR\])" strContent=re.Replace(strContent,"<br><IMG SRC=../images/rar.gif border=0> <a href=""$2"">点击下载该文件</a>") re.Pattern="(\[UPLOAD=(.[^\[]*)\])(.[^\[]*)(\[\/UPLOAD\])" strContent= re.Replace(strContent,"<br><A HREF=""$3"" TARGET=_blank><IMG align=left SRC=""$3"" border=0 alt=按此在新窗口浏览图片></A>") re.Pattern="(\[URL\])(http:\/\/.[^\[]*)(\[\/URL\])" strContent= re.Replace(strContent,"<A HREF=""$2"" TARGET=_blank>$2</A>") re.Pattern="(\[URL\])(.[^\[]*)(\[\/URL\])" strContent= re.Replace(strContent,"<A HREF=""http://$2"" TARGET=_blank>$2</A>") re.Pattern="(\[URL=(http:\/\/.[^\[]*)\])(.[^\[]*)(\[\/URL\])" strContent= re.Replace(strContent,"<A HREF=""$2"" TARGET=_blank>$3</A>") re.Pattern="(\[URL=(.[^\[]*)\])(.[^\[]*)(\[\/URL\])" strContent= re.Replace(strContent,"<A HREF=""http://$2"" TARGET=_blank>$3</A>") re.Pattern="(\[EMAIL\])(\S+\@.[^\[]*)(\[\/EMAIL\])" strContent= re.Replace(strContent,"<img align=absmiddle src=../images/email1.gif><A HREF=""mailto:$2"">$2</A>") re.Pattern="(\[EMAIL=(\S+\@.[^\[]*)\])(.[^\[]*)(\[\/EMAIL\])" strContent= re.Replace(strContent,"<img align=absmiddle src=../images/email1.gif><A HREF=""mailto:$2"" TARGET=_blank>$3</A>") 're.Pattern = "^(http://[A-Za-z0-9\./=\?%\-&_~`@':+!]+)" 'strContent = re.Replace(strContent,"<a target=_blank href=$1>$1</a>") 're.Pattern = "(http://[A-Za-z0-9\./=\?%\-&_~`@':+!]+)$" 'strContent = re.Replace(strContent,"<a target=_blank href=$1>$1</a>") 're.Pattern = "[^>=""](http://[A-Za-z0-9\./=\?%\-&_~`@':+!]+)" 'strContent = re.Replace(strContent,"<a target=_blank href=$1>$1</a>") re.Pattern = "^(ftp://[A-Za-z0-9\./=\?%\-&_~`@':+!]+)" strContent = re.Replace(strContent,"<a target=_blank href=$1>$1</a>") re.Pattern = "(ftp://[A-Za-z0-9\./=\?%\-&_~`@':+!]+)$" strContent = re.Replace(strContent,"<a target=_blank href=$1>$1</a>") re.Pattern = "[^>=""](ftp://[A-Za-z0-9\.\/=\?%\-&_~`@':+!]+)" strContent = re.Replace(strContent,"<a target=_blank href=$1>$1</a>") re.Pattern = "^(rtsp://[A-Za-z0-9\./=\?%\-&_~`@':+!]+)" strContent = re.Replace(strContent,"<a target=_blank href=$1>$1</a>") re.Pattern = "(rtsp://[A-Za-z0-9\./=\?%\-&_~`@':+!]+)$" strContent = re.Replace(strContent,"<a target=_blank href=$1>$1</a>") re.Pattern = "[^>=""](rtsp://[A-Za-z0-9\.\/=\?%\-&_~`@':+!]+)" strContent = re.Replace(strContent,"<a target=_blank href=$1>$1</a>") re.Pattern = "^(mms://[A-Za-z0-9\./=\?%\-&_~`@':+!]+)" strContent = re.Replace(strContent,"<a target=_blank href=$1>$1</a>") re.Pattern = "(mms://[A-Za-z0-9\./=\?%\-&_~`@':+!]+)$" strContent = re.Replace(strContent,"<a target=_blank href=$1>$1</a>") re.Pattern = "[^>=""](mms://[A-Za-z0-9\.\/=\?%\-&_~`@':+!]+)" strContent = re.Replace(strContent,"<a target=_blank href=$1>$1</a>") if strIcons = "1" then re.Pattern="(\[em(.[^\[]*)\])" strContent=re.Replace(strContent,"<img src=pic/em$2.gif border=0 align=middle>") end if re.Pattern="(\[norun\])(.[^\[]*)(\[\/norun\])" strContent=re.Replace(strContent,"<table width='100%' border='0' cellspacing='0' cellpadding='6' bgcolor=#F7F7F7><td><b>以下内容为程序代码:</b><br>$2</td></table>") re.Pattern="(\[code\])(.[^\[]*)(\[\/code\])" strContent=re.Replace(strContent,"<form><table width='100%' border='0' cellspacing='0' cellpadding='6' bgcolor=#F7F7F7><td><b>以下内容为程序代码:</b><br><textarea style='border:solid 1px #EEAF71;width:100%' name='dbg' rows='10'>$2</textarea><br><input type='button' class='button' value='运行此代码' style='width:80px' onclick='runit(this.form.dbg)'> <input type='button' class='button' value='复制到剪贴板' style='width:90px' onclick='copyit(this.form.dbg)'> <input type='button' class='button' value='代码另存为' style='width:80px' onclick='saveAs(this.form.dbg)'></td></table></form>") re.Pattern="(\[color=(.[^\[]*)\])(.[^\[]*)(\[\/color\])" strContent=re.Replace(strContent,"<font color=$2>$3</font>") re.Pattern="(\[face=(.[^\[]*)\])(.[^\[]*)(\[\/face\])" strContent=re.Replace(strContent,"<font face=$2>$3</font>") re.Pattern="(\[align=(.[^\[]*)\])(.*)(\[\/align\])" strContent=re.Replace(strContent,"<div align=$2>$3</div>") re.Pattern="(\[QUOTE\])(.*)(\[\/QUOTE\])" strContent=re.Replace(strContent,"<table cellpadding=0 cellspacing=0 border=0 WIDTH=94% bgcolor=#F6F6F6 align=center><tr><td><table width=100% cellpadding=5 cellspacing=1 border=0><TR><TD BGCOLOR='"&abgcolor&"'>$2</table></table><br>") re.Pattern="(\[fly\])(.*)(\[\/fly\])" strContent=re.Replace(strContent,"<marquee width=90% behavior=alternate scrollamount=3>$2</marquee>") re.Pattern="(\[move\])(.*)(\[\/move\])" strContent=re.Replace(strContent,"<MARQUEE scrollamount=3>$2</marquee>") re.Pattern="\[GLOW=*([0-9]*),*(#*[a-z0-9]*),*([0-9]*)\](.[^\[]*)\[\/GLOW]" strContent=re.Replace(strContent,"<table width=$1 style=""filter:glow(color=$2, strength=$3)"">$4</table>") re.Pattern="\[SHADOW=*([0-9]*),*(#*[a-z0-9]*),*([0-9]*)\](.[^\[]*)\[\/SHADOW]" strContent=re.Replace(strContent,"<table width=$1 style=""filter:shadow(color=$2, strength=$3)"">$4</table>") re.Pattern="(\[i\])(.[^\[]*)(\[\/i\])" strContent=re.Replace(strContent,"<i>$2</i>") re.Pattern="(\[u\])(.[^\[]*)(\[\/u\])" strContent=re.Replace(strContent,"<u>$2</u>") re.Pattern="(\[b\])(.[^\[]*)(\[\/b\])" strContent=re.Replace(strContent,"<b>$2</b>") re.Pattern="(\[fly\])(.[^\[]*)(\[\/fly\])" strContent=re.Replace(strContent,"<marquee>$2</marquee>") re.Pattern="(\[size=1\])(.[^\[]*)(\[\/size\])" strContent=re.Replace(strContent,"<font size=1>$2</font>") re.Pattern="(\[size=2\])(.[^\[]*)(\[\/size\])" strContent=re.Replace(strContent,"<font size=2>$2</font>") re.Pattern="(\[size=3\])(.[^\[]*)(\[\/size\])" strContent=re.Replace(strContent,"<font size=3>$2</font>") re.Pattern="(\[size=4\])(.[^\[]*)(\[\/size\])" strContent=re.Replace(strContent,"<font size=4>$2</font>") strContent = doCode(strContent, "[list]", "[/list]", "<ul>", "</ul>") strContent = doCode(strContent, "[list=1]", "[/list]", "<ol type=1>", "</ol id=1>") strContent = doCode(strContent, "[list=a]", "[/list]", "<ol type=a>", "</ol id=a>") strContent = doCode(strContent, "[*]", "[/*]", "<li>", "</li>") re.Pattern="(\[center\])(.[^\[]*)(\[\/center\])" strContent=re.Replace(strContent,"<center>$2</center>") strContent=ChkBadWords(strContent) set re=Nothing UBBCode=strContent end function function doCode(fString, fOTag, fCTag, fROTag, fRCTag) fOTagPos = Instr(1, fString, fOTag, 1) fCTagPos = Instr(1, fString, fCTag, 1) while (fCTagPos > 0 and fOTagPos > 0) fString = replace(fString, fOTag, fROTag, 1, 1, 1) fString = replace(fString, fCTag, fRCTag, 1, 1, 1) fOTagPos = Instr(1, fString, fOTag, 1) fCTagPos = Instr(1, fString, fCTag, 1) wend doCode = fString end function function IsValidEmail(email) dim names, name, i, c 'Check for valid syntax in an email address. IsValidEmail = true names = Split(email, "@") if UBound(names) <> 1 then IsValidEmail = false exit function end if for each name in names if Len(name) <= 0 then IsValidEmail = false exit function end if for i = 1 to Len(name) c = Lcase(Mid(name, i, 1)) if InStr("abcdefghijklmnopqrstuvwxyz_-.", c) <= 0 and not IsNumeric(c) then IsValidEmail = false exit function end if next if Left(name, 1) = "." or Right(name, 1) = "." then IsValidEmail = false exit function end if next if InStr(names(1), ".") <= 0 then IsValidEmail = false exit function end if i = Len(names(1)) - InStrRev(names(1), ".") if i <> 2 and i <> 3 then IsValidEmail = false exit function end if if InStr(email, "..") > 0 then IsValidEmail = false end if end function %>