📄 ubbcode.asp
字号:
<%
'入口参数:strContent内容,PostUserGroup用户组ID,PostType使用类型(1表示帖子,2表示公告,3表示短信)
function DvBCode(strContent,PostUserGroup,PostType)
'HTML Code
if PostType=3 or PostType=2 then
redim Board_Setting(23)
Board_Setting(6)=1
Board_Setting(5)=0:Board_Setting(7)=1
Board_Setting(8)=1:Board_Setting(9)=1
Board_Setting(10)=0:Board_Setting(11)=0
Board_Setting(12)=0:Board_Setting(13)=0
Board_Setting(14)=0:Board_Setting(15)=0
Board_Setting(23)=0
end if
if Cint(Board_Setting(5)) <> 1 then
strContent = dvHTMLEncode(strContent)
else
strContent = HTMLcode(strContent)
end if
'UbbCode
if Cint(Board_Setting(6))<>1 and PostUserGroup>2 then
DvBCode=strContent
exit function
end if
dim re
dim po,ii,iii
dim SplitBuyUser,iPostBuyUser
dim reContent
Set re=new RegExp
re.IgnoreCase =true
re.Global=True
po=0
ii=0
re.Pattern="(javascript)"
strContent=re.Replace(strContent,"javascript")
re.Pattern="(jscript:)"
strContent=re.Replace(strContent,"jscript:")
re.Pattern="(js:)"
strContent=re.Replace(strContent,"js:")
re.Pattern="(value)"
strContent=re.Replace(strContent,"value")
re.Pattern="(about:)"
strContent=re.Replace(strContent,"about:")
re.Pattern="(file:)"
strContent=re.Replace(strContent,"file:")
re.Pattern="(document.cookie)"
strContent=re.Replace(strContent,"documents.cookie")
re.Pattern="(vbscript:)"
strContent=re.Replace(strContent,"vbscript:")
re.Pattern="(vbs:)"
strContent=re.Replace(strContent,"vbs:")
re.Pattern="(on(mouse|exit|error|click|key))"
strContent=re.Replace(strContent,"on$2")
'Img Code
if Cint(Board_Setting(7)) = 1 or PostUserGroup<4 then
re.Pattern="\[IMG\](http|https|ftp):\/\/(\S+?)\[\/IMG\]"
strContent=re.Replace(strContent,"<a onfocus=this.blur() href=""$1://$2"" target=_blank><IMG SRC=""$1://$2"" border=0 alt=按此在新窗口浏览图片 onload=""javascript:if(this.width>screen.width-333)this.width=screen.width-333""></a>")
re.Pattern="\[UPLOAD=(gif|jpg|jpeg|bmp|png)\](.[^\[]*)(gif|jpg|jpeg|bmp|png)\[\/UPLOAD\]"
strContent= re.Replace(strContent,"<br><IMG SRC=""images/files/$1.gif"" border=0>此主题相关图片如下:<br><A HREF=""$2$1"" TARGET=_blank><IMG SRC=""$2$1"" border=0 alt=按此在新窗口浏览图片 onload=""javascript:if(this.width>screen.width-333)this.width=screen.width-333""></A>")
else
re.Pattern="\[IMG\](http|https|ftp):\/\/(\S+?)\[\/IMG\]"
strContent=re.Replace(strContent,"<IMG SRC=""images/files/gif.gif"" border=0><a onfocus=this.blur() href=""$1://$2"" target=_blank>$1://$2</a>")
re.Pattern="\[UPLOAD=(gif|jpg|jpeg|bmp|png)\](.[^\[]*)(gif|jpg|jpeg|bmp|png)\[\/UPLOAD\]"
strContent= re.Replace(strContent,"<br><IMG SRC=""images/files/$1.gif"" border=0><A HREF=""$2$1"" TARGET=_blank>$2$1</A>")
end if
re.Pattern="\[UPLOAD=(\S+?)\](.+?)\[\/UPLOAD\]"
strContent= re.Replace(strContent,"<br><IMG SRC=""images/files/$1.gif"" border=0> <a href=""$2"">点击浏览该文件</a>")
'多媒体标签
if cint(Board_Setting(9))=1 or PostUserGroup<4 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=$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>")
re.Pattern="(\[FLASH\])(.+?)(\[\/FLASH\])"
strContent= re.Replace(strContent,"<a href=""$2"" TARGET=_blank><IMG SRC=pic/swf.gif border=0 alt=点击开新窗口欣赏该FLASH动画! height=16 width=16>[全屏欣赏]</a><br><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>")
re.Pattern="(\[FLASH=*([0-9]*),*([0-9]*)\])(.+?)(\[\/FLASH\])"
strContent= re.Replace(strContent,"<a href=""$4"" TARGET=_blank><IMG SRC=pic/swf.gif border=0 alt=点击开新窗口欣赏该FLASH动画! height=16 width=16>[全屏欣赏]</a><br><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=$2 height=$3><PARAM NAME=movie VALUE=""$4""><PARAM NAME=quality VALUE=high><embed src=""$4"" quality=high pluginspage='http://www.macromedia.com/shockwave/download/index.cgi?P1_Prod_Version=ShockwaveFlash' type='application/x-shockwave-flash' width=$2 height=$3>$4</embed></OBJECT>")
re.Pattern="(\[sound\])(.+?)(\[\/sound\])"
strContent=re.Replace(strContent,"<a href=""$2"" target=_blank><IMG SRC=pic/mid.gif border=0 alt='背景音乐'></a><bgsound src=""$2"" loop=""-1"">")
else
re.Pattern="\[DIR=*([0-9]*),*([0-9]*)\](.+?)\[\/DIR]"
strContent=re.Replace(strContent,"<a href=$3 target=_blank>$3</a>")
re.Pattern="\[QT=*([0-9]*),*([0-9]*)\](.+?)\[\/QT]"
strContent=re.Replace(strContent,"<a href=$3 target=_blank>$3</a>")
re.Pattern="\[MP=*([0-9]*),*([0-9]*)\](.+?)\[\/MP]"
strContent=re.Replace(strContent,"<a href=$3 target=_blank>$3</a>")
re.Pattern="\[RM=*([0-9]*),*([0-9]*)\](.+?)\[\/RM]"
strContent=re.Replace(strContent,"<a href=$3 target=_blank>$3</a>")
re.Pattern="(\[FLASH\])(.+?)(\[\/FLASH\])"
strContent= re.Replace(strContent,"<IMG SRC="&Forum_info(7)&"swf.gif border=0><a href=$2 target=_blank>$2</a>")
re.Pattern="(\[FLASH=*([0-9]*),*([0-9]*)\])(.+?)(\[\/FLASH\])"
strContent= re.Replace(strContent,"<IMG SRC="&Forum_info(7)&"swf.gif border=0><a href=$4 target=_blank>$4</a>")
end if
'积分可见
if (Cint(Board_Setting(11))=1 or PostUserGroup<4) and PostType=1 then
re.Pattern="(^.*)(\[point=*([0-9]*)\])(.+?)(\[\/point\])(.*)"
po=re.Replace(strContent,"$3")
if IsNumeric(po) then
ii=int(po)
else
ii=0
end if
if membername=username or myuserep>ii then
strContent=re.Replace(strContent,"$1<hr noshade size=1>以下为需要积分达到<B>$3</B>才能浏览的内容<BR>$4<hr noshade size=1>$6")
else
strContent=re.Replace(strContent,"$1<hr noshade size=1><font color="&Forum_body(8)&">此内容要求积分达到$3以上才可以浏览</font><hr noshade size=1>$6")
end if
else
re.Pattern="(\[point=*([0-9]*)\])(.+?)(\[\/point\])"
strContent=re.Replace(strContent,"$3")
end if
'魅力可见
if (Cint(Board_Setting(12))=1 or PostUserGroup<4) and PostType=1 then
re.Pattern="(^.*)(\[UserCP=*([0-9]*)\])(.+?)(\[\/UserCP\])(.*)"
po=re.Replace(strContent,"$3")
if IsNumeric(po) then
ii=int(po)
else
ii=0
end if
if membername=username or myusercp>ii then
strContent=re.Replace(strContent,"$1<hr noshade size=1>以下为需要魅力达到<B>$3</B>才能浏览的内容<BR>$4<hr noshade size=1>$6")
else
strContent=re.Replace(strContent,"$1<hr noshade size=1><font color="&Forum_body(8)&">此内容要求魅力达到$3以上才可以浏览</font><hr noshade size=1>$6")
end if
else
re.Pattern="(\[UserCP=*([0-9]*)\])(.+?)(\[\/UserCP\])"
strContent=re.Replace(strContent,"$3")
end if
'威望可见
if (Cint(Board_Setting(13))=1 or PostUserGroup<4) and PostType=1 then
re.Pattern="(^.*)(\[Power=*([0-9]*)\])(.+?)(\[\/Power\])(.*)"
po=re.Replace(strContent,"$3")
if IsNumeric(po) then
ii=int(po)
else
ii=0
end if
if membername=username or mypower>ii then
strContent=re.Replace(strContent,"$1<hr noshade size=1>以下为需要威望达到<B>$3</B>才能浏览的内容<BR>$4<hr noshade size=1>$6")
else
strContent=re.Replace(strContent,"$1<hr noshade size=1><font color="&Forum_body(8)&">此内容要求威望达到$3以上才可以浏览</font><hr noshade size=1>$6")
end if
else
re.Pattern="(\[Power=*([0-9]*)\])(.+?)(\[\/Power\])"
strContent=re.Replace(strContent,"$3")
end if
'文章可见
if (Cint(Board_Setting(14))=1 or PostUserGroup<4) and PostType=1 then
re.Pattern="(^.*)(\[Post=*([0-9]*)\])(.+?)(\[\/Post\])(.*)"
po=re.Replace(strContent,"$3")
if IsNumeric(po) then
ii=int(po)
else
ii=0
end if
if membername=username or myArticle>ii then
strContent=re.Replace(strContent,"$1<hr noshade size=1>以下为需要文章数达到<B>$3</B>才能浏览的内容<BR>$4<hr noshade size=1>$6")
else
strContent=re.Replace(strContent,"$1<hr noshade size=1><font color="&Forum_body(8)&">此内容要求文章数达到$3以上才可以浏览</font><hr noshade size=1>$6")
end if
else
re.Pattern="(\[Post=*([0-9]*)\])(.+?)(\[\/Post\])"
strContent=re.Replace(strContent,"$3")
end if
'金钱可见
if (Cint(Board_Setting(10))=1 or PostUserGroup<4) and PostType=1 then
re.Pattern="(^.*)(\[money=*([0-9]*)\])(.+?)(\[\/money\])(.*)"
po=re.Replace(strContent,"$3")
if IsNumeric(po) then
ii=int(po)
else
ii=0
end if
if membername=username or mymoney>ii then
strContent=re.Replace(strContent,"$1<hr noshade size=1>以下为需要金钱数达到<B>$3</B>才能浏览的内容<BR>$4<hr noshade size=1>$6")
else
strContent=re.Replace(strContent,"$1<hr noshade size=1><font color="&Forum_body(8)&">此内容要求金钱数达到$3以上才可以浏览</font><hr noshade size=1>$6")
end if
else
re.Pattern="(\[money=*([0-9]*)\])(.+?)(\[\/money\])"
strContent=re.Replace(strContent,"$3")
end if
'回复可见
if (Cint(Board_Setting(15))=1 or PostUserGroup<4) and PostType=1 then
if instr(lcase(strContent),"[replyview]")>0 and instr(lcase(strContent),"[/replyview]")>0 then
dim vrs
set vrs=conn.execute("select AnnounceID from "&TotalUseTable&" where rootid="&Announceid&" and PostUserID="&UserID)
re.Pattern="(\[replyview\])(\S+?)(\[\/replyview\])"
if vrs.eof and vrs.bof then
strContent=re.Replace(strContent,"<hr noshade size=1><font color="&Forum_body(8)&">此内容需要回复才能浏览</font><hr noshade size=1>")
else
strContent=re.Replace(strContent,"<hr noshade size=1>以下内容为需要回复才能浏览<BR>$2<hr noshade size=1>")
end if
set vrs=nothing
end if
else
re.Pattern="(\[replyview\])(\S+?)(\[\/replyview\])"
strContent=re.Replace(strContent,"$2")
end if
'购买帖子
if (Cint(Board_Setting(23))=1 or PostUserGroup<4) and PostType=1 then
re.Pattern="(^.*)(\[usemoney=*([0-9]*)\])(.+?)(\[\/usemoney\])(.*)"
po=re.Replace(strContent,"$3")
if IsNumeric(po) then
ii=int(po)
else
ii=0
end if
if membername=username then
if (not isnull(PostBuyUser)) and PostBuyUser<>"" then
SplitBuyUser=split(PostBuyUser,"|")
iPostBuyUser="<option value=0>已购买用户</option>"
for iii=0 to ubound(SplitBuyUser)
iPostBuyUser=iPostBuyUser & "<option value="&iii&">"&SplitBuyUser(iii)&"</option>"
next
else
iPostBuyUser="<option value=0>还没有用户购买</option>"
end if
strContent=re.Replace(strContent,"$1<hr noshade size=1>以下为需要金钱数达到<B>$3</B>才能浏览的内容 <select size=1 name=buyuser>"&iPostBuyUser&"</select><BR>$4<hr noshade size=1>$6")
elseif mymoney>ii then
if membername=username or master or boardmaster or superboardmaster then
if (not isnull(PostBuyUser)) and PostBuyUser<>"" then
SplitBuyUser=split(PostBuyUser,"|")
iPostBuyUser="<select name=buyuser size=1><option value=0>已购买用户</option>"
for iii=0 to ubound(SplitBuyUser)
iPostBuyUser=iPostBuyUser & "<option value="&iii&">"&SplitBuyUser(iii)&"</option>"
next
iPostBuyUser=iPostBuyUser & "</select>"
else
iPostBuyUser="<select name=buyuser size=1><option value=0>还没有用户购买</option></select>"
end if
end if
if (not isnull(PostBuyUser)) and PostBuyUser<>"" then
if instr("|"&PostBuyUser&"|","|"&membername&"|")>0 then
strContent=re.Replace(strContent,"$1<hr noshade size=1>以下为需要花<B>$3</B>金钱才能购买并浏览的内容,您已经购买本贴<BR>$4<hr noshade size=1>$6")
else
strContent=re.Replace(strContent,"$1<Form action=""BuyPost.asp"" mothod=post><font color="&Forum_body(8)&">此帖子内容需要您花$3金钱来购买浏览 <input type=hidden name=boardid value="&boardid&"><input type=hidden value="&replyid&" name=replyid><input type=hidden value="&AnnounceID&" name=id><input type=hidden value="&totalusetable&" name=posttable><input type=submit name=submit value=好黑啊…我…我买了!> "&iPostBuyUser&"</font></form>$6")
end if
else
strContent=re.Replace(strContent,"$1<Form action=""BuyPost.asp"" mothod=post><font color="&Forum_body(8)&">此帖子内容需要您花$3金钱来购买浏览 <input type=hidden name=boardid value="&boardid&"><input type=hidden value="&replyid&" name=replyid><input type=hidden value="&AnnounceID&" name=id><input type=hidden value="&totalusetable&" name=posttable><input type=submit name=submit value=好黑啊…我…我买了!> "&iPostBuyUser&"</font></form>$6")
end if
else
strContent=re.Replace(strContent,"$1<hr noshade size=1><font color="&Forum_body(8)&">此内容要求金钱数达到$3以上才可以购买并浏览</font><hr noshade size=1>$6")
end if
else
re.Pattern="(\[usemoney=*([0-9]*)\])(.+?)(\[\/usemoney\])"
strContent=re.Replace(strContent,"$3")
end if
re.Pattern="(\[URL\])(\S+?)(\[\/URL\])"
strContent= re.Replace(strContent,"<A HREF=""$2"" TARGET=_blank>$2</A>")
re.Pattern="(\[URL=(\S+?)\])(.+?)(\[\/URL\])"
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -