专注WEB开发 分享经验,沉淀知识

PHP屏蔽用户名称的部分字符

 作者:chenxing  时间:2017-05-19 10:24  阅读:123  评论:

这里用到的知识点 ** 字符串的截取替换 ** 和获取** 中文字符串的长度 ** 。你可能会疑问为什么和屏蔽手机号一样直接用substr_replace()处理

上一篇文章介绍了“PHP屏蔽手机号部分位数”的一般做法。今儿再看看PHP如何屏蔽用户名称的部分字符。

应用效果图:

PHP屏蔽用户名称的部分字符

代码实现:


/**
 * 名称字符串适用*号做部分隐藏
 */
 function replace_str_hide($str){
    $resplace_str = array('*', '**', '***', '****', '*****');
    $str_len = mb_strlen($str,'UTF-8');
    switch (true) {
        case $str_len <= 2 && $str_len > 1://1-2用1个*号取代
            return mb_substr($str, 0, -strlen($resplace_str[0])) . $resplace_str[0];
            break;
        case $str_len <= 4 && $str_len > 2://2-4用2个*号取代
            return mb_substr($str, 0, -strlen($resplace_str[1])) . $resplace_str[1];
            break;
        case $str_len <= 6 && $str_len > 4://4-6用3个*号取代
            return mb_substr($str, 0, -strlen($resplace_str[2])) . $resplace_str[2];
            break;
        case $str_len <= 8 && $str_len > 6://6-8用4个*号取代
            return mb_substr($str, 0, -strlen($resplace_str[3])) . $resplace_str[3];
            break;
        case strlen($str) > 8://8以上用5个*号取代
            return mb_substr($str, 0, -strlen($resplace_str[4])) . $resplace_str[4];
            break;
        default:
            return $str;
            break;
    }
 }
echo replace_str_hide('我是你的眼');
//输出的结果:我是***

这里用到的知识点 字符串的截取替换 和获取 中文字符串的长度 。你可能会疑问为什么不和屏蔽手机号一样直接用substr_replace()处理。这里主要牵扯到php很多函数并没对中文字符的处理。中文不想英文字符一样,一个英文字符占一个字节,一个汉字字符占多个字节,具体占多少字节呢?要看你用的什么编码,UTF-8占3个字节,gbk占2个字节。substr_replace('$str','replace', start, length)中start和length是按照英文字符计算的,包括获取字符长度的strlen()。总之,牵扯到中文字符的计算都要注意你所使用的php内置方法是否兼容中文字符,防止计算字符不准或者出现截取乱码现象的产生。

除特别注明外,本网站所有文章均为作者原创。 或分享自己的编程经验,或探讨工作中的问题,或聊以人生趣事。 转载请注明出处来自 https://www.qiusuoweb.com/41.html

发布评论

 提交评论
有人回复时邮件通知我

 评论(0)

站长头像
chenxing(PHP攻城狮)

运营天数

总访问量

文章数量

-

-

-

交流群:157451741

新浪微博:草莽兴

 近期文章

一年时间又回到这里

 2019-07-27 16:54  140

PHP字符串转数组的三种场景

 2018-05-05 01:32  195

PHP如何遍历字符串?

 2018-05-04 00:56  1186

api接口常见的安全问题和解决方案

 2018-05-03 23:20  936

 最新评论

 lisheng: 05月09日 19:26
兴哥牛B加油哈兴哥成功的道路上你又进了一步 哈哈
来源: 一年时间又回到这里
 心态炸裂: 03月24日 10:54
No3.blindcomfirm 多了一个l,望改正!!!
来源: 微信小程序获取input值的总结
 666666: 11月08日 13:49
66666
来源: 一年时间又回到这里
 花花草草: 10月14日 14:58
tp5不是已经提前开了吗
来源: _SESSION变量未定义?
 疯了: 10月10日 13:40
你好呀,我使用docker构建的 把整个项目给了777 并把runtime的所有者给了nginx php的运行者还是报错
来源: thinkphp5的mkdir() Permission denied问题探讨
 mesecretme: 09月30日 15:30
有个问题,有没有发现用redis保存session的话,session清空redis的key还没过期,会依然保留的,这是值变成空了
来源: php项目redis实现session共享案例