关于php trim方法的错误理解致使的问题

场景

php中的截取字符串先后字符包括有:ltrim,rtrim,trim三个方法php

下面的例子中只以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中的一些操做字符串函数,多加了基层判断code

if (substr($str, 0, strlen($character_mask)) == $character_mask) {
            echo substr($str, strlen($character_mask));
  }
相关文章
相关标签/搜索