主頁(yè) > 知識(shí)庫(kù) > 解決preg_match匹配過(guò)多字符長(zhǎng)度的限制的思路分析

解決preg_match匹配過(guò)多字符長(zhǎng)度的限制的思路分析

熱門(mén)標(biāo)簽:服務(wù)器配置 電子圍欄 團(tuán)購(gòu)網(wǎng)站 Linux服務(wù)器 銀行業(yè)務(wù) Mysql連接數(shù)設(shè)置 阿里云 科大訊飛語(yǔ)音識(shí)別系統(tǒng)
但是官方的文檔里面沒(méi)有說(shuō)明這一點(diǎn)。

于是開(kāi)始測(cè)試:將要匹配的字串不斷縮短,直到縮為原來(lái)1/5的時(shí)候可以正常匹配了,所以更加確定了。

到google里一搜,終于找到了解決方案:在php.ini中加入(隨便放到哪里,我是直接放第一行的)

pcre.backtrack_limit=-1

再次使用preg_match函數(shù)測(cè)試一下,大概1300多行上萬(wàn)個(gè)字符的字符串也能夠匹配了。

項(xiàng)目中,用preg_match正則提取目標(biāo)內(nèi)容,死活有問(wèn)題,代碼測(cè)得死去活來(lái)。

后來(lái)發(fā)現(xiàn)“pcre.backtrack_limit ”的值默認(rèn)只設(shè)了100000。

解決辦法:ini_set(‘pcre.backtrack_limit', 999999999);

注:這個(gè)參數(shù)在php 5.2.0版本之后可用。

另外說(shuō)說(shuō)關(guān)于:pcre.recursion_limit

pcre.recursion_limit是PCRE的遞歸限制,這個(gè)項(xiàng)如果設(shè)很大的值,會(huì)消耗所有進(jìn)程的可用堆棧,最后導(dǎo)致PHP崩潰。

也可以通過(guò)修改配置來(lái)限制:ini_set(‘pcre.recursion_limit', 99999);

實(shí)際項(xiàng)目應(yīng)用中,最好也對(duì)內(nèi)存進(jìn)行限定設(shè)置:ini_set(‘memory_limit', '64M'); , 這樣就比較穩(wěn)妥妥嘎。

標(biāo)簽:萍鄉(xiāng) 廣元 大理 棗莊 衡水 蚌埠 江蘇 衢州

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《解決preg_match匹配過(guò)多字符長(zhǎng)度的限制的思路分析》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266