php过滤非法字符并代替输出,如何过滤高亮显示非法字符

如何过滤高亮显示非法字符

更新时间:2006年10月09日 00:00:00   作者:

//我只是做一个测试,如果再用类似tmd的字符串,一定要注意,如果字符串中的字符出现在$StartReplaceHtml或者$EndReplaceHtml中,你需要修改下面的preg_replace中的规则

$CheckedMessage="Hello!!他X的..他....X...的....How are you m d ";     //the message to be checked

echo $CheckedMessage."
";

$CheckedWords=array("他X的","tmd");//要过滤的非法字符,如果你需要把单个的字符也过滤,比如:他ererX000的过滤出来他,X,的,你就没必要把过滤字符设置成"他X的"只要设置成$CheckedWords=array("他","X","的");就可以了

$StartReplaceHtml="";

$EndReplaceHtml="";

$CheckOther= true;//设置标示位,是否显示单个的字符,如果设置成true,下面的if(strstr……)就不需要了

for($i=0;$i

if(strstr($CheckedMessage,$CheckedWords[$i])){ //此处可去掉

$CheckedMessage=eregi_replace($CheckedWords[$i],$StartReplaceHtml.$CheckedWords[$i].$EndReplaceHtml,$CheckedMessage);//如果只过滤诸如"他X的"字符串(是字符串,不是单个字符),可以直接写这句,同时把$CheckOther设置成false

}

if($CheckOther == true){

$CharStringLength = strlen($CheckedWords[$i]);

for($j=0;$j

$AssumeLength=1;//假定截取长度

if(ord(substr($CheckedWords[$i],$j,$AssumeLength))>0xa0){//如果汉字,假定长度加一

$AssumeLength++;

}

$SubstrChar = substr($CheckedWords[$i],$j,$AssumeLength);

$CheckedMessage=preg_replace("/(?中的t不会被替换,如果需要过滤掉在$StartReplace或者在$EndReplaceHtml中的的字符,需要修改规则,否则的话将会出现乱码

if($AssumeLength!=1){//如果当前截取字符为汉字

$j++;

}

}

}

}

echo $CheckedMessage;

//只是一个简单的测试,希望对你有所帮助,希望你能举一反三,好运!

?>

相关文章

1a1b05c64693fbf380aa1344a7812747.png

亲密接触PHP之PHP语法学习笔记1...2006-12-12

4f55910a645b073bc4fc65dc10dc14bd.png

BBS(php & mysql)完整版(一)...2006-10-10

0ea3c7666119d5615e582f823fb3fad6.png

php 目录与文件处理-郑阿奇(续) ,需要的朋友可以参考下。2011-07-07

4f96a78db829b1556ff16de21e013c7a.png

PHP中实现进程间通讯...2006-10-10

8cc1031babc6aff2319f1c6af8544aa0.png

PHP面向对象的使用教程 简单数据库连接...2006-11-11

0c932a99bb7b6f23c937db507070cc7b.png

今天小编就为大家分享一篇关于PHP的mysqli_rollback()函数讲解,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧2019-01-01

cca732bf65a93ed2ec0ac80c638460fe.png

PHPRPC 是一个轻型的、安全的、跨网际的、跨语言的、跨平台的、跨环境的、跨域的、支持复杂对象传输的、支持引用参数传递的、支持内容输出重定向的、支持分级错误处理的、支持会话的、面向服务的高性能远程过程调用协议。2011-10-10

2d9f31f2af7b675a3d153d2b7f1035a7.png

定制404错误页面,并发信给管理员的程序...2006-10-10

b452cee8ec5cd9e58ab98eba17281e59.png

深入了解php4(2)--重访过去...2006-10-10

f4838ec7e2d4da28e0b57d4e852dadd4.png

我用php+mysql写的留言本...2006-10-10

最新评论

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值