PHP5.2下preg_replace函數的問題

preg_replace 使用的超過了php5.2默認允許的字節

也就是pcre.backtrack_limit和pcre.recursion_limit的大小的問題。

Discuz!6.0.0正式版程序發布以來,大家都熱火朝天的升級中,但是部分插件在6.0下出現了問題

比如http://www.discuz.net/viewthread.php?tid=559133這個銀行插件

在php爲5.2.0及以上的環境下安裝以後會出現白屏的問題

從Discuz!用戶的角度考慮,我們需要去協助插件作者解決這個問題

下面說下我的解決過程,希望能給大家一些建議吧

第一:此插件在5.5的情況下可以正常運行,但是6.0下就白屏了

Discuz!6.0爲了增加模板緩存文件的可讀性,增加了緩存文件的縮進,而確實修改過部分templates.func.php的模板處理部分,

莫非是這個原因?開始我初步確定是這裏的問題,因爲用5.5的部分代碼替換修改過的代碼,就表現正常,但是很郁悶的沒有找到原因

第二步:懷疑是bank.htm這個模板書寫格式的問題,于是我很郁悶的開始分析模板,說實話,模板大了分析起來真的很頭疼。結果顯然又沒有找到原因。比較郁悶的說

第二步:然後發現將此模板拆分以後,就正常執行了,這時候我初步懷疑是不是正則匹配的bug在大數據量的時候出現了錯誤,于是我就上bugs.php.net開始搜索了http://bugs.php.net/search.php?c … ace&x=3&y=5在這裏找啊找啊找,于是終于找到了這裏http://bugs.php.net/bug.php?id=39405,突然間發現居然是5.2配置的問題,在調整大pcre.backtrack_limit和pcre.recursion_limit之後問題解決

之所以寫這麽詳細就是想一起分享下我解決問題的思路:)

 
replace()函數的另類用法
  在使用replace()函數的過程中,一般教程或書本上的使用方法都是——replace(str,"aaa","bbb")   實際上,有些時候我們過于注重書本的教導,對于函數本身的使用並沒有從VB SCRIPT規則上予以考慮。  比如repla...查看完整版>>replace()函數的另類用法
 
Sybase數據庫SQL語句REPLACE的對應函數
Sybase數據庫SQL語句REPLACE的對應函數 Oracle: rReplace := 'UPDATE CA_SYSRGT SET PARTID=REPLACE(PARTID,'''+strDept+''','''')'; PARTID爲字段名稱 strDept 爲要查找的字符串 ''''爲要替換的字符串,本例子將strD...查看完整版>>Sybase數據庫SQL語句REPLACE的對應函數
 
JSP中的字符替換函數 str_replace()實現
// // StrReplace.java // package forum; import java.util.*; /** * Title: * Description: * Copyright: Copyright (c) 2001 * Company: * @author * @version 1.0 */ public class StrReplace { public StrRepla...查看完整版>>JSP中的字符替換函數 str_replace()實現