>백엔드 개발 >PHP 튜토리얼 >php中,用preg_match_all()正则检测600k左右长度字符串的合法性

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

WBOY
WBOY원래의
2016-06-06 20:10:391176검색

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也左右不了。建议你选用其他方法来处理这些内容,比如先分割,在循环检查每个小段。

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.