本篇文章给大家带来的内容是关于php trim方法的使用会导致的问题分析,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。
场景
php中的截取字符串前后字符包括有:ltrim,rtrim,trim三个方法
下面的例子中只以ltrim方法做举例
在我之前的认知中(当然我很水,从没看过这块源码),如果我想要删除字符串左边的空字符串,空制表符之类的,那么我就直接使用ltrim($str)即可
如果我想要删除指定字符的时候,比如说现在有个字符串helloworld,我要截取掉头部的h字符,直接var_dump(ltrim("helloworld", "h"));即可得到我期望的结果输出elloworld
以上的都是在我以为的范围内,我也一直都是这么使用的,直到有一次我们有个需求要在一些字符串上做openssl_encrypt加密,加密之后做个base64,然后拼接上我们的特殊的字符串前缀KO:,每次加密完成后拼接KO:字符,同样的,解密之前先把KO:拆出去在解密,结果发现解密怎么解都是失败,后来打了几个断点发现是ltrim的时候和预期结果不一样
复现
- <?php
- // 以下做一个简单的情景复现
- $str = "abccabdefg";
- $character_mask = “abc”;
- var_dump(ltrim($str, $character_mask)); // 输出结果为 bdefg,而不是只截取前三位的abc
原因分析
经过上面的小demo,大家应该就知道原因是啥了,说的最简单通俗的就是它把前面的$str做一个轮训,一个字符一个字符的在后面的$character_mask里面看是不是在其中,如果是的话则进行截取,不在的话停止运行
ltrim代码形式的表达:
- <?php
- $str = "abcccabdecbag";
- $res = '';
- $character_mask = 'abc';
- $arrStr = str_split($str); // 字符串转数组
- for ($i=0; $i<=count($arrStr); $i++) {
- if(strpos($character_mask, $arrStr[$i]) !== false) {
- unset($arrStr[$i]);
- } else {
- break;
- }
- }
- echo ltrim($str, $character_mask);
- echo "/r/n";
- echo implode($arrStr);
- echo "/r/n";
解决方案
解决方案就是使用php中的一些操作字符串函数,多加了基层判断
- if (substr($str, 0, strlen($character_mask)) == $character_mask) {
- echo substr($str, strlen($character_mask));
- }
新闻热点
疑难解答