關於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));
  }
相關文章
相關標籤/搜索