快速业务通道

论坛、聊天室中滤除HTML标记 - 编程入门网

作者 佚名技术 来源 NET编程 浏览 发布时间 2012-06-22

论坛、聊天室中滤除HTML标记

时间:2010-12-25 yesky wayne

由于论坛、聊天室都是开放的系统,每一个有权限的用户都可以在其中畅所欲言。但是往往有一些别有用心的用户就会利用它们的开放性在其中捣乱,比如在聊天时或在论坛中发文章时,嵌入HTML标记,使系统混乱。因此,想编写一个健壮的论坛或聊天室就必须把用户发送来的HTML标记滤去。

让我们来分析一下如何滤去这些标记。我们都知道,HTML标记是由两个尖括号“<”、“>”和其中的一些语句组成,如等,只要把我们接收到的HTML语句中的“<”、“>”相应换成<和>,在发回就可以了。现在思路明了多了吧。现在让我们看看这个过程在Java程序中如何实现,为了节省篇幅,我只写了过滤的函数。

Public String htmlFilter(String inputString); If(inputString.length()= =0 || inputString= = null)   {   return inputString;   } ///如果接收到的字符串为空值或者长度为零,则返回该字符串, //因为空字符串是不可能*有<和>的 StringBuffer str=new StringBuffer(inputString.length()+6); //创建空的缓冲区 char c=’’; for(int i=0 ;i< inputString.length();i ++) { c= inputString.charAt(i);//逐个扫描输入的字符串,取下inputString中第i +1个字符 if (c= =’<’) { str.append(“<”); }//如果c为‘<’,则在str缓冲中加入”<”代替‘<’ else if (c = =’>’) { str.append(“<”); }//如果c为‘>’,则在str缓冲中加入”>”代替‘>’ else { str.append (c); //如果既无’<’ 也无’>’则直接把c中的值写入缓冲 } } return str.toString(); //返回滤过HTML标记的字符串 }

你看,这样的难题就被一个简简单单的Java函数解决了。你只需把它加到你的论坛或聊天使程序中就行了。

凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

分享到: 更多

Copyright ©1999-2011 厦门凌众科技有限公司 厦门优通互联科技开发有限公司 All rights reserved

地址(ADD):厦门软件园二期望海路63号701E(东南融通旁) 邮编(ZIP):361008

电话:0592-5908028 传真:0592-5908039 咨询信箱:web@lingzhong.cn 咨询OICQ:173723134

《中华人民共和国增值电信业务经营许可证》闽B2-20100024  ICP备案:闽ICP备05037997号