您好,登錄后才能下訂單哦!
本篇文章為大家展示了解決preg_match匹配過多字符長度的限制的思路分析是怎樣的,內容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。
但是官方的文檔里面沒有說明這一點。
于是開始測試:將要匹配的字串不斷縮短,直到縮為原來1/5的時候可以正常匹配了,所以更加確定了。
到google里一搜,終于找到了解決方案:在php.ini中加入(隨便放到哪里,我是直接放第一行的)
pcre.backtrack_limit=-1
再次使用preg_match函數測試一下,大概1300多行上萬個字符的字符串也能夠匹配了。
項目中,用preg_match正則提取目標內容,死活有問題,代碼測得死去活來。
后來發現“pcre.backtrack_limit ”的值默認只設了100000。
解決辦法:ini_set(‘pcre.backtrack_limit', 999999999);
注:這個參數在php 5.2.0版本之后可用。
另外說說關于:pcre.recursion_limit
pcre.recursion_limit是PCRE的遞歸限制,這個項如果設很大的值,會消耗所有進程的可用堆棧,最后導致PHP崩潰。
也可以通過修改配置來限制:ini_set(‘pcre.recursion_limit', 99999);
實際項目應用中,最好也對內存進行限定設置:ini_set(‘memory_limit', '64M'); , 這樣就比較穩妥妥嘎。
上述內容就是解決preg_match匹配過多字符長度的限制的思路分析是怎樣的,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。