php字符串过滤

php字符串过滤,第1张

$str = preg_replace("/^.+=(.+)$/", "新内容\\1", $str)//过滤等于号前面的所有字符串(包括等于号)

$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

//输出 中文字符啊

?>


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/zaji/7318105.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-04
下一篇 2023-04-04

发表评论

登录后才能评论

评论列表(0条)

保存