$str = preg_replace("/^(.+)=.+$/", "\\1"."新内容", $str)//过滤等于号后面的所有字符串(包括等于号)
function filterGBK_SpecialChars($str){
$str =urlencode($str)//将关键字编码
//下面的必须写在一行,不可换行截断
$str=preg_replace("/(%7E|%60|%21|%40|%23|%24|%25|%5E|%26|%27|
%2A|%28|%29|%2B|%7C|%5C|%3D|\-|_|%5B|%5D|%7D|%7B|%3B|%22|%3A|
%3F|%3E|%3C|%2C|\.|%2F|%A3%BF|%A1%B7|%A1%B6|%A1%A2|%A1%A3|%A3%AC|
%7D|%A1%B0|%A3%BA|%A3%BB|%A1%AE|%A1%AF|%A1%B1|%A3%FC|%A3%BD|%A1%AA|
%A3%A9|%A3%A8|%A1%AD|%A3%A4|%A1%A4|%A3%A1|%A1%AB|%A3%FB|%A3%FD|%A1%BE|
%A1%BF|)+/",'',$str)
$str =urldecode($str)//将过滤后的关键字解码
return $str
}
$str='广~·@#¥%……&*()——+|-=、{}【】:“”‘’~“《》,。?、州?海【,鲜。餐“”】(,厅) '
echo filterGBK_SpecialChars($str)
首先需要先把带有中文的字符串进行编码转化,由GB2312编码转化为UTF-8编码。这样是为了PHP正则表达式可以正确的去匹配
然后通过preg_match_all()函数以及相应的中文匹配正则表达式,把所有的中文匹配出来
最后,把匹配到的中文字符串再转为B2312编码,这样做是为了可以在网页编码为GB2312上正确显示。
例如:
<?php
$str = "ddddvvv(,中文.)dfdsfds字符啊."
//把GB2312编码转化为 UTF-8编码
$str = mb_convert_encoding($str, 'UTF-8', 'GB2312')
//正则匹配
preg_match_all('/[\x{4e00}-\x{9fff}]+/u', $str, $matches)
//把匹配到的数组连接为字符串
$str = implode('', $matches[0])
//把UTF-8编码转化为 GB2312编码
$str = mb_convert_encoding($str, 'GB2312', 'UTF-8')
echo $str
//输出 中文字符啊
?>
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)