命名空间Imports System.Text.RegularExpressions++++++++++++++++++ Function ubb(ByVal vstr As String) '替换HTML标记及换行处理
vstr = Server.HtmlEncode(vstr)
vstr = Replace(vstr, Chr(32), " ")
vstr = Replace(vstr, vbCrLf, "<br>")
Dim xface As Integer
If xface = 1 Then
'表情转换,数值型变量xface=1时,允许转换
vstr = Replace(vstr, ":)", "<img src=""em/em1.gif"">")
vstr = Replace(vstr, ":(", "<img src=""em/em2.gif"">")
vstr = Replace(vstr, ":o", "<img src=""em/em3.gif"">")
vstr = Replace(vstr, ":D", "<img src=""em/em4.gif"">")
vstr = Replace(vstr, ";)", "<img src=""em/em5.gif"">")
vstr = Replace(vstr, ":p", "<img src=""em/em6.gif"">")
vstr = Replace(vstr, ":cool:", "<img src=""em/em7.gif"">")
vstr = Replace(vstr, ":mad:", "<img src=""em/em8.gif"">")
vstr = Replace(vstr, ":eek:", "<img src=""em/em9.gif"">")
vstr = Replace(vstr, ":?:", "<img src=""em/em0.gif"">")
End If Dim objregex As Regex '屏蔽JS等等
objregex = New Regex("javascript")
vstr = objregex.Replace(vstr, "javascript")
objregex = New Regex("jscript:")
vstr = objregex.Replace(vstr, "jscript:")
objregex = New Regex("js:")
vstr = objregex.Replace(vstr, "js:")
objregex = New Regex("value")
vstr = objregex.Replace(vstr, "value")
objregex = New Regex("about:")
vstr = objregex.Replace(vstr, "about:")
objregex = New Regex("file:")
vstr = objregex.Replace(vstr, "file:")
objregex = New Regex("document.cookie")
vstr = objregex.Replace(vstr, "documents.cookie")
objregex = New Regex("vbscript:")
vstr = objregex.Replace(vstr, "vbscript:")
objregex = New Regex("vbs:")
vstr = objregex.Replace(vstr, "vbs:")
objregex = New Regex("(on(mouse|exit|error|click|key))")
vstr = objregex.Replace(vstr, "on$2")
objregex = New Regex("script")
vstr = objregex.Replace(vstr, "script") 'UBB转换
'url
objregex = New Regex("\[url\](http|https|ftp):\/\/(.[^\[]*)\[\/url\]")
vstr = objregex.Replace(vstr, "<a href=""$1://$2"" TARGET=""_blank"">$1://$2</a>")
'EMAIL
objregex = New Regex("(\[email\])(\S+\@.[^\[]*)(\[\/email\])")
vstr = objregex.Replace(vstr, "<A HREF=""mailto:$2"">$2</A>") objregex = New Regex("(\[email=(\S+\@.[^\[]*)\])(.[^\[]*)(\[\/email\])")
vstr = objregex.Replace(vstr, "<A HREF=""mailto:$2"" TARGET=_blank>$3</A>") 'IMG
objregex = New Regex("\[img\](http|https|ftp):\/\/(.[^\[]*)\[\/img\]")
vstr = objregex.Replace(vstr, "<br><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>")
'COLOR
objregex = New Regex("\[color=(.[^\[]*)\](.[^\[]*)\[\/color\]")
vstr = objregex.Replace(vstr, "<font color=""$1"">$2</font>")
'u
objregex = New Regex("\[u\](.*)\[\/u\]")
vstr = objregex.Replace(vstr, "<u>$1</u>")
'B
objregex = New Regex("\[b\](.*)\[\/b\]")
vstr = objregex.Replace(vstr, "<b>$1</b>")
'I
objregex = New Regex("\[i\](.*)\[\/i\]")
vstr = objregex.Replace(vstr, "<i>$1</i>")
'FLY
objregex = New Regex("\[fly\](.*)\[\/fly\]")
vstr = objregex.Replace(vstr, "<marquee width=""80%"" behavior=""alternate"" scrollamount=""3"">$1</marquee>")
'SHADOW
objregex = New Regex("\[shadow=*([0-9]*),*(#*[a-z0-9]*),*([0-9]*)\](.[^\[]*)\[\/shadow]")
vstr = objregex.Replace(vstr, "<table width=$1 style=""filter:shadow(color=$2, strength=$3)"">$4</table>") 'CODE
objregex = New Regex("\[code\](.*)\[\/code\]")
vstr = objregex.Replace(vstr, "<table width=""80%"" border=""0"" cellpadding=""2"" cellspacing=""0"" bgcolor=""#99FFCC"" style=""border:1px solid #000000;font-size:9pt;font-family:tahoma""><tr><td>$1</td></tr></table>") 'glow
objregex = New Regex("\[glow=*([0-9]*),*(#*[a-z0-9]*),*([0-9]*)\](.[^\[]*)\[\/glow]")
vstr = objregex.Replace(vstr, "<table width=$1 style=""filter:glow(color=$2, strength=$3)"">$4</table>") 'move
objregex = New Regex("(\[move\])(.*)(\[\/move\])")
vstr = objregex.Replace(vstr, "<marquee scrollamount=3>$2</marquee>") 'center
objregex = New Regex("(\[center\])(.[^\[]*)(\[\/center\])")
vstr = objregex.Replace(vstr, "<center>$2</center>") 'flash
objregex = New Regex("(\[flash\])(.[^\[]*)(\[\/flash\])")
vstr = objregex.Replace(vstr, "<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>") 'quote
objregex = New Regex("(\[quote\])(.*)(\[\/quote\])")
vstr = objregex.Replace(vstr, "<TABLE cellSpacing=1 cellPadding=10 width=100% bgColor=#000000 border=0><TR><TD bgColor=#ffffff>$2</td></tr></table><br>") 'html
objregex = New Regex("(\[html\])(.[^\[]*)(\[\/html\])")
vstr = objregex.Replace(vstr, "<table width='100%' border='0' cellspacing='0' cellpadding='6' bgcolor=''><td><b>以下内容为程序代码:</b><br>$2</td></table>") 'face
objregex = New Regex("(\[face=(.[^\[]*)\])(.[^\[]*)(\[\/face\])")
vstr = objregex.Replace(vstr, "<font FACE=$2>$3</font>") 'size
objregex = New Regex("(\[size=1\])(.[^\[]*)(\[\/size\])")
vstr = objregex.Replace(vstr, "<font size=1>$2</font>") objregex = New Regex("(\[size=2\])(.[^\[]*)(\[\/size\])")
vstr = objregex.Replace(vstr, "<font size=2>$2</font>") objregex = New Regex("(\[size=3\])(.[^\[]*)(\[\/size\])")
vstr = objregex.Replace(vstr, "<font size=3>$2</font>") objregex = New Regex("(\[size=4\])(.[^\[]*)(\[\/size\])")
vstr = objregex.Replace(vstr, "<font size=4>$2</font>") objregex = New Regex("(\[size=5\])(.[^\[]*)(\[\/size\])")
vstr = objregex.Replace(vstr, "<font size=5>$2</font>")
'自动识别URL
objregex = New Regex("\[url=(http:\/\/.[^\[]*)\](.[^\[]*)(\[\/url\])")
vstr = objregex.Replace(vstr, "<a href=""$1"" target=""_blank"">$2</a>")
objregex = New Regex("^(http://[A-Za-z0-9\./=\?%\-&_~`@':+!]+)")
vstr = objregex.Replace(vstr, "<a href=""$1"" target=""_blank"">$1</a>")
objregex = New Regex("(http://[A-Za-z0-9\./=\?%\-&_~`@':+!]+)$")
vstr = objregex.Replace(vstr, "<a target=_blank href=$1>$1</a>")
objregex = New Regex("[^>=""](http://[A-Za-z0-9\./=\?%\-&_~`@':+!]+)")
vstr = objregex.Replace(vstr, "<a target=_blank href=$1>$1</a>") '完成,还可以自己扩展 ubb = vstr End Function以前我问过这个问题。。
vstr = Server.HtmlEncode(vstr)
vstr = Replace(vstr, Chr(32), " ")
vstr = Replace(vstr, vbCrLf, "<br>")
Dim xface As Integer
If xface = 1 Then
'表情转换,数值型变量xface=1时,允许转换
vstr = Replace(vstr, ":)", "<img src=""em/em1.gif"">")
vstr = Replace(vstr, ":(", "<img src=""em/em2.gif"">")
vstr = Replace(vstr, ":o", "<img src=""em/em3.gif"">")
vstr = Replace(vstr, ":D", "<img src=""em/em4.gif"">")
vstr = Replace(vstr, ";)", "<img src=""em/em5.gif"">")
vstr = Replace(vstr, ":p", "<img src=""em/em6.gif"">")
vstr = Replace(vstr, ":cool:", "<img src=""em/em7.gif"">")
vstr = Replace(vstr, ":mad:", "<img src=""em/em8.gif"">")
vstr = Replace(vstr, ":eek:", "<img src=""em/em9.gif"">")
vstr = Replace(vstr, ":?:", "<img src=""em/em0.gif"">")
End If Dim objregex As Regex '屏蔽JS等等
objregex = New Regex("javascript")
vstr = objregex.Replace(vstr, "javascript")
objregex = New Regex("jscript:")
vstr = objregex.Replace(vstr, "jscript:")
objregex = New Regex("js:")
vstr = objregex.Replace(vstr, "js:")
objregex = New Regex("value")
vstr = objregex.Replace(vstr, "value")
objregex = New Regex("about:")
vstr = objregex.Replace(vstr, "about:")
objregex = New Regex("file:")
vstr = objregex.Replace(vstr, "file:")
objregex = New Regex("document.cookie")
vstr = objregex.Replace(vstr, "documents.cookie")
objregex = New Regex("vbscript:")
vstr = objregex.Replace(vstr, "vbscript:")
objregex = New Regex("vbs:")
vstr = objregex.Replace(vstr, "vbs:")
objregex = New Regex("(on(mouse|exit|error|click|key))")
vstr = objregex.Replace(vstr, "on$2")
objregex = New Regex("script")
vstr = objregex.Replace(vstr, "script") 'UBB转换
'url
objregex = New Regex("\[url\](http|https|ftp):\/\/(.[^\[]*)\[\/url\]")
vstr = objregex.Replace(vstr, "<a href=""$1://$2"" TARGET=""_blank"">$1://$2</a>")
objregex = New Regex("(\[email\])(\S+\@.[^\[]*)(\[\/email\])")
vstr = objregex.Replace(vstr, "<A HREF=""mailto:$2"">$2</A>") objregex = New Regex("(\[email=(\S+\@.[^\[]*)\])(.[^\[]*)(\[\/email\])")
vstr = objregex.Replace(vstr, "<A HREF=""mailto:$2"" TARGET=_blank>$3</A>") 'IMG
objregex = New Regex("\[img\](http|https|ftp):\/\/(.[^\[]*)\[\/img\]")
vstr = objregex.Replace(vstr, "<br><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>")
'COLOR
objregex = New Regex("\[color=(.[^\[]*)\](.[^\[]*)\[\/color\]")
vstr = objregex.Replace(vstr, "<font color=""$1"">$2</font>")
'u
objregex = New Regex("\[u\](.*)\[\/u\]")
vstr = objregex.Replace(vstr, "<u>$1</u>")
'B
objregex = New Regex("\[b\](.*)\[\/b\]")
vstr = objregex.Replace(vstr, "<b>$1</b>")
'I
objregex = New Regex("\[i\](.*)\[\/i\]")
vstr = objregex.Replace(vstr, "<i>$1</i>")
'FLY
objregex = New Regex("\[fly\](.*)\[\/fly\]")
vstr = objregex.Replace(vstr, "<marquee width=""80%"" behavior=""alternate"" scrollamount=""3"">$1</marquee>")
'SHADOW
objregex = New Regex("\[shadow=*([0-9]*),*(#*[a-z0-9]*),*([0-9]*)\](.[^\[]*)\[\/shadow]")
vstr = objregex.Replace(vstr, "<table width=$1 style=""filter:shadow(color=$2, strength=$3)"">$4</table>") 'CODE
objregex = New Regex("\[code\](.*)\[\/code\]")
vstr = objregex.Replace(vstr, "<table width=""80%"" border=""0"" cellpadding=""2"" cellspacing=""0"" bgcolor=""#99FFCC"" style=""border:1px solid #000000;font-size:9pt;font-family:tahoma""><tr><td>$1</td></tr></table>") 'glow
objregex = New Regex("\[glow=*([0-9]*),*(#*[a-z0-9]*),*([0-9]*)\](.[^\[]*)\[\/glow]")
vstr = objregex.Replace(vstr, "<table width=$1 style=""filter:glow(color=$2, strength=$3)"">$4</table>") 'move
objregex = New Regex("(\[move\])(.*)(\[\/move\])")
vstr = objregex.Replace(vstr, "<marquee scrollamount=3>$2</marquee>") 'center
objregex = New Regex("(\[center\])(.[^\[]*)(\[\/center\])")
vstr = objregex.Replace(vstr, "<center>$2</center>") 'flash
objregex = New Regex("(\[flash\])(.[^\[]*)(\[\/flash\])")
vstr = objregex.Replace(vstr, "<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>") 'quote
objregex = New Regex("(\[quote\])(.*)(\[\/quote\])")
vstr = objregex.Replace(vstr, "<TABLE cellSpacing=1 cellPadding=10 width=100% bgColor=#000000 border=0><TR><TD bgColor=#ffffff>$2</td></tr></table><br>") 'html
objregex = New Regex("(\[html\])(.[^\[]*)(\[\/html\])")
vstr = objregex.Replace(vstr, "<table width='100%' border='0' cellspacing='0' cellpadding='6' bgcolor=''><td><b>以下内容为程序代码:</b><br>$2</td></table>") 'face
objregex = New Regex("(\[face=(.[^\[]*)\])(.[^\[]*)(\[\/face\])")
vstr = objregex.Replace(vstr, "<font FACE=$2>$3</font>") 'size
objregex = New Regex("(\[size=1\])(.[^\[]*)(\[\/size\])")
vstr = objregex.Replace(vstr, "<font size=1>$2</font>") objregex = New Regex("(\[size=2\])(.[^\[]*)(\[\/size\])")
vstr = objregex.Replace(vstr, "<font size=2>$2</font>") objregex = New Regex("(\[size=3\])(.[^\[]*)(\[\/size\])")
vstr = objregex.Replace(vstr, "<font size=3>$2</font>") objregex = New Regex("(\[size=4\])(.[^\[]*)(\[\/size\])")
vstr = objregex.Replace(vstr, "<font size=4>$2</font>") objregex = New Regex("(\[size=5\])(.[^\[]*)(\[\/size\])")
vstr = objregex.Replace(vstr, "<font size=5>$2</font>")
'自动识别URL
objregex = New Regex("\[url=(http:\/\/.[^\[]*)\](.[^\[]*)(\[\/url\])")
vstr = objregex.Replace(vstr, "<a href=""$1"" target=""_blank"">$2</a>")
objregex = New Regex("^(http://[A-Za-z0-9\./=\?%\-&_~`@':+!]+)")
vstr = objregex.Replace(vstr, "<a href=""$1"" target=""_blank"">$1</a>")
objregex = New Regex("(http://[A-Za-z0-9\./=\?%\-&_~`@':+!]+)$")
vstr = objregex.Replace(vstr, "<a target=_blank href=$1>$1</a>")
objregex = New Regex("[^>=""](http://[A-Za-z0-9\./=\?%\-&_~`@':+!]+)")
vstr = objregex.Replace(vstr, "<a target=_blank href=$1>$1</a>") '完成,还可以自己扩展 ubb = vstr End Function以前我问过这个问题。。
解决方案 »
免费领取超大流量手机卡,每月29元包185G流量+100分钟通话, 中国电信官方发货