当前位置: 首页 > 图文教程 > 网络编程 > ASP > 过滤掉危险的HTML标记:script,ifame,object

ASP
IIS 错误 Server Application Error 详细解决方法
On Error Resume Next 语句
ASP常用函数:CStrIP()
ASP常用函数:CLngIP()
ASP常用函数:XMLEncode
查看所有的Server Variables的环境变量
随机提取N条记录 推荐
一个可以自动创建多级目录的函数
ASP常用函数收藏乱七八糟未整理版
ASP常用函数:HTMLDecode
15种ASP技巧
ASP常用函数:IIF()
ASP常用函数:ArrayToxml
ASP常用函数:ReplaceHTML
改进性能和样式的24个ASP 技巧
如何将长的标题用省略号收尾
如何保持数据库输出格式不变
学习ASP和编程的28个观点
Asp实现假静态
初学asp者必看

ASP 中的 过滤掉危险的HTML标记:script,ifame,object


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-09-13   浏览: 69 ::
收藏到网摘: n/a

对于提交的HTML代码,如果含有script,iframe,frameset等标记,对网站本身会构成一定的潜在威胁,使用下面的函数可以过滤掉指定的HTML标记。
注:
1.对于单标记(如:<hr />,<br />等),因其对网站本身不会构成威胁,故未将单标记纳过过滤范围。
2.参数strHTML:待过滤处理的HTML代码内容
3.参数strTAGs:为待过滤掉的HTML标记名,各标记名以英文逗号( , )为间隔
复制代码 代码如下:
<%
'Wrtten by i{At}CnLei.Com
Function lFilterBadHTML(byval strHTML,byval strTAGs)
Dim objRegExp,strOutput
Dim arrTAG,i
arrTAG=Split(strTAGs,",")
Set objRegExp = New Regexp
strOutput=strHTML
objRegExp.IgnoreCase = True
objRegExp.Global = True
For i=0 to UBound(arrTAG)
objRegExp.Pattern = "<"&arrTAG(i)&"[\s\S]+</"&arrTAG(i)&"*>"
strOutput = objRegExp.Replace(strOutput, "")
Next
Set objRegExp = Nothing
lFilterBadHTML = strOutput
End Function

'Example
Dim sPageCont
sPageCont= "...网页正文内容..."
sPageCont=FilterBadHTML(sPageCont,"script,iframe,object,table")
%>