本篇文章給大家帶來的內容是關于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)); }
以上就是php trim方法的使用會導致的問題分析的詳細內容,PHP教程
鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。
新聞熱點
疑難解答