Rumah  >  Artikel  >  pembangunan bahagian belakang  >  php中,用preg_match_all()正则检测600k左右长度字符串的合法性

php中,用preg_match_all()正则检测600k左右长度字符串的合法性

WBOY
WBOYasal
2016-06-06 20:10:391090semak imbas

600K左右的字符串,是数字+分隔符。因为是用户提交的,所以要检测是否合法。我这里用preg_match_all+正则来检测,字符串短的时候,是可以检测的,没有问题,当字符串超过100k的时候,nginx就会502
我也查到了问题所在,pcre中设定了回溯值
后来,我根据网上给出的解决方法

<code>ini_set("pcre.backtrack_limit",1000000);</code>

依然是502
正则代码是:

<code>/^(\d{5}(&|$)){1,}$/</code>

字符串格式是:

<code>12345&12346&12347&……99999</code>

请问有别的方法可以解决这个问题吗?
或者是我哪里的设置不对?

回复内容:

600K左右的字符串,是数字+分隔符。因为是用户提交的,所以要检测是否合法。我这里用preg_match_all+正则来检测,字符串短的时候,是可以检测的,没有问题,当字符串超过100k的时候,nginx就会502
我也查到了问题所在,pcre中设定了回溯值
后来,我根据网上给出的解决方法

<code>ini_set("pcre.backtrack_limit",1000000);</code>

依然是502
正则代码是:

<code>/^(\d{5}(&|$)){1,}$/</code>

字符串格式是:

<code>12345&12346&12347&……99999</code>

请问有别的方法可以解决这个问题吗?
或者是我哪里的设置不对?

即使设置了pcre.backtrack_limit还是有可能崩溃的,因为巨大的回溯可能会爆栈,这是系统级别的限制,PHP也左右不了。建议你选用其他方法来处理这些内容,比如先分割,在循环检查每个小段。

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn