$str=preg_replace("/[attach]/is","111",$str);这一句如何把111替换成可以执行的PHP代码
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了$str=preg_replace("/[attach]/is","111",$str);这一句如何把111替换成可以执行的PHP代码,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含4165字,纯文字阅读大概需要6分钟。
内容图文
![$str=preg_replace("/[attach]/is","111",$str);这一句如何把111替换成可以执行的PHP代码](/upload/InfoBanner/zyjiaocheng/201/e706f4c2ab624cd9a109e89f366a0b3f.jpg)
比如$str=preg_replace("/\[attach\]/is","
回复讨论(解决方案)
$message=preg_replace("/\[url\](http:[^\]]*?)\[\/url\]/ies","_cuturl('\\1')",$message);function _cuturl($msg){ $new=cutstr($msg,20); return $new;}
在正则后面加符号/e,就可以调用函数,在里面就可以执行php的操作
$str=preg_replace("/\[attach\]/is","",$str);
这个是BBCODE的PHP替换。你应该是想实现类似DISCUZ的那种附件BBCODE。
要想回调可以使用 preg_replace_callback。
<?php //author: default7<default7#zbphp.com$str = preg_replace_callback("/\[attach\](\d+)\[\/attach\]/isUe",function($attachId = 0){ //todo $row = $db->query("select * from tb where id=$id ")->row(); return '';},$str);
原理如上,具体代码自己测试一下。
这个是BBCODE的PHP替换。你应该是想实现类似DISCUZ的那种附件BBCODE。
要想回调可以使用 preg_replace_callback。
<?php //author: default7<default7#zbphp.com$str = preg_replace_callback("/\[attach\](\d+)\[\/attach\]/isUe",function($attachId = 0){ //todo $row = $db->query("select * from tb where id=$id ")->row(); return '';},$str);
原理如上,具体代码自己测试一下。
修正:
$str = preg_replace_callback("/\[attach\]\s*(\d+)\s*\[\/attach\]/isUe",function($match){ //todo $id = $match[1]; $row = $db->query("select * from tb where id=$id ")->row(); return $row ? '' : '';},$str);
$str=preg_replace("/\[attach\]/is","<img src='".."'" width="280"/>",$str)
这个是BBCODE的PHP替换。你应该是想实现类似DISCUZ的那种附件BBCODE。
要想回调可以使用 preg_replace_callback。
<?php //author: default7<default7#zbphp.com$str = preg_replace_callback("/\[attach\](\d+)\[\/attach\]/isUe",function($attachId = 0){ //todo $row = $db->query("select * from tb where id=$id ")->row(); return '';},$str);
原理如上,具体代码自己测试一下。
修正:
$str = preg_replace_callback("/\[attach\]\s*(\d+)\s*\[\/attach\]/isUe",function($match){ //todo $id = $match[1]; $row = $db->query("select * from tb where id=$id ")->row(); return $row ? '' : '';},$str);
出现错误提示:Parse error: syntax error, unexpected T_FUNCTION in
指向$str = preg_replace_callback("/\[attach\]\s*(\d+)\s*\[\/attach\]/isUe",function($match){这一行
你的 php 版本是多少?
php5.2
function get($id) { //$value = 这里是相关操作的代码 return $value;}$str = preg_replace("/\[(attach)\]/ise", "get('$1')", $str);
也可以
function get($r) { //$value = 这里是相关操作的代码 return $value;}$str = preg_replace_callback("/\[(attach)\]/is", "get", $str);
dz的手机版不显示图片,所以我想自己写一个 显示人页面。
function get($r) { $value = SELECT * FROM `bbs_forum_attachment_$row[tableid]` where tid =id return $value;}$str = preg_replace_callback("/\[(attach)\]/is", "get", $str);
where tid =id 这个ID如何得到
你 print_r($r) 就可看到
你 print_r($r) 就可看到
function get($r) { $value = "SELECT * FROM `bbs_forum_attachment_9` where tid =$r" return $value;}$str = preg_replace_callback("/\[(attach)\]/is", "get", $str);
错误提示:Parse error: syntax error, unexpected T_RETURN
第二行的结尾分号少写了。
第二行的结尾分号少写了。
呵呵;我改成
function get($r) { $value = "SELECT * FROM `bbs_forum_attachment_9` where tid =$r"; return $value;}$str = preg_replace_callback("/\[(attach)\]/is", "get", $str);
可是前天输出
SELECT * FROM `bbs_forum_attachment_9` where tid =Array26588
我想要的是SELECT * FROM `bbs_forum_attachment_9` where tid =26588 不要Array 怎么弄
我改成单引号前台输出 SELECT * FROM `bbs_forum_attachment_9` where tid =$r
是不是这段php语句没有执行,直接转成文本了
26588 从哪里来的? 在get方法里面 print_r($r); 得到什么?
改成$str = preg_replace_callback("/\[attach\](.+?)\[\/attach\]/is", "get", $str); 之后
输出:SELECT * FROM `bbs_forum_attachment_9` where tid =Array
26588 从哪里来的? 在get方法里面 print_r($r); 得到什么?
在get方法里面 print_r($r); 得到 值是 1
26588应该是第一次没有过滤干净
看不懂了,print_r($r); 怎么可能是1呢?
php5.2
忘了写明,我写的那个要 PHP 5.5+
php5.2 怎么写呢
内容总结
以上是互联网集市为您收集整理的$str=preg_replace("/[attach]/is","111",$str);这一句如何把111替换成可以执行的PHP代码全部内容,希望文章能够帮你解决$str=preg_replace("/[attach]/is","111",$str);这一句如何把111替换成可以执行的PHP代码所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。