草庐IT

Preg_Match

全部标签

php - preg_match_all 导致 child 死亡

我有一个接受图像复制/粘贴的TinyMCE表单。输入完评论后,按“发布”,它会提交表单,解析内容并显示在屏幕对话中。我正在尝试使用preg_match_all从POSTed变量中提取base64编码数据。我的大多数模式都有效,但这个导致Apache崩溃。崩溃是无声的,我从Apache/PHP得到的唯一提示是error.log文件中的一行:[error]childdiedwithsignal11我已经将它缩小到preg_match_all中的这种模式以及我在第二组之后有一个*的事实,它包含一个类定义,旨在跟随base64字符以引号结尾。示例图像可在此处获得(文本文件,base64编码):

php - preg_replace 不适用于某些单词/字符

$str='کسنےموسیٰکےبارےمیںسناہے؟';$str=preg_replace('/(?这无法替换موسیٰ。它应该给出کسنےMusaکےبارےمیںsunaہے؟而不是给出کسنےموسیٰکےبارےمیںsunaے͟。所有以ٰ结尾的单词都会发生这种情况,例如تعالیٰ。它适用于ٰ位于单词中间的单词(没有以ٰ开头的单词)。这是否意味着\b不能与ٰ一起使用?是错误吗? 最佳答案 原因是单词边界在以下位置匹配:Beforethefirstcharacterinthestring,ifthefirstchar

php - Preg_match 字母数字 - _' "和空格

谁有允许字母数字和-_",'以及空格的正则表达式? 最佳答案 试试这个:/^[A-Za-z0-9-_",'\s]+$/ 关于php-Preg_match字母数字-_'"和空格,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/1733920/

php - Preg_replace,只替换( )中的模式部分?

很抱歉这个基本问题,但我一直在查看我能找到的关于preg_replace的所有信息,但我仍然无法弄清楚。我有一个大字符串,例如:$string='#tjs{fassdaf}#fsk{fssf}#fskff{casf}';当我这样做时,它会替换整个模式,而不仅仅是()中的部分,因为我希望它这样做。我想知道如何才能替换()中的部分。谢谢$pattern='/#.*tjs.*\{.*(.*)\}/imsU';$replacement="test";$return_string=preg_replace($string,$pattern,$replacement);预期被替换的字符串:'#tj

php - 如何使用PHP preg_replace 正则表达式查找和替换文本?

我写了这段PHP代码来做一些替换:functioncambio($txt){$from=array('/\+\>([^\+\>]+)\text\1','\1',);returnpreg_replace($from,$to,$txt);}echocambio('ThefruitImostlikeis:+>%apple%%banna%%orange%结果是:ThefruitImostlikeis:applebannaorange.但是我需要识别水果的span标签,如下所示:ThefruitImostlikeis:applebananacoco.我会买一个水果给谁发现一个正则表达式来完成这个

php - preg_replace + UTF-8 在一台服务器上不起作用,但在另一台服务器上起作用

echopreg_match("/\b(בדיקה|מילה)\b/iu","זוהיבדיקה");出于某种原因,这段代码在我测试过的几台服务器上返回1,但在一台特定服务器上返回0。PCRE编译时支持UTF-8和Unicode属性支持。可能是什么问题? 最佳答案 PHP使用的PCRE版本之间可能存在差异。PHP和PCRE版本:http://php.net/pcre.installation你应该使用8.10+(PHP5.3.4+)Version8.1025-Jun-2010:AddedPCRE_UCPtomake\b,\d,\s,

php - 如何在 preg_replace() 函数中使用 substr() 函数?

这是我目前所拥有的,但无论我尝试什么,我的album-content都不会被substr()截断。$gallery=preg_replace('/()(.*?)()/e',"'$1'.substr(\"$2\",0,50).'$3'",$gallery);更新:原来我的类名不正确,我的正则表达式似乎确实有效。我只需要执行另一个str_replace()来取消转义输出。$gallery=preg_replace('/()(.*?)()/e',"'$1'.substr(\"$2\",0,50).'$3'",$gallery);$gallery=str_replace('\"album-de

PHP : non-preg_match version of: preg_match ("/[^a-z0-9]/i", $a, $match)?

假设字符串是:$a="abc-def"if(preg_match("/[^a-z0-9]/i",$a,$m)){$i="istoppedscanning'$a'becauseIfoundaviolationinitwhilescanningitfromlefttoright.Theviolationwas:$m[0]";}echo$i;上面的例子:应该指出“-”是违规的。我想知道是否有非preg_match方法可以做到这一点。如果有非preg_match方法可以运行1000或100万次,我可能会运行基准测试,看看哪个更快、更高效。在基准测试中,“$a”会更长。确保它不会尝试扫描整个“$

替换字符串中的 PHP preg_quote

我使用preg_replace并且我想在替换字符串中包含一个url。我如何引用该字符串?看来preg_quote仅适用于搜索模式。$replace='\1'.addslashes($url).'\3'.addslashes($title).'\4'; 最佳答案 需要逃避addslashes是不够的preg_quote转义太多参见thisdemo.正如Mario评论的那样,您可以使用addcslashes($str,"\\$")。 关于替换字符串中的PHPpreg_quote,我们在Sta

php - Codeigniter:将 sess_match_ip 设置为 FALSE 是否仍然安全

我正在处理一个网站,来自某些国家/地区的访问者在使用codeigniter缓存系统时遇到问题。缓存在一两个请求后被删除。经过深入调查,我将sess_match_ip和sess_match_useragent设置为FALSE,现在一切正常。将这些配置保留为FALSE是否安全?谢谢 最佳答案 它的安全性稍差,但通常是必需的,尤其是在处理移动设备或代理服务器银行后面的用户时。为确保您尽可能安全,请务必将数据库用于session,并务必设置加密key和sess_encrypt_cookie,以便混淆存储在cookie中的少量信息。您可以做的