我有一个小的编程问题.我试图在一个类中执行一个函数,我有一个数组,我正在使用array_walk在该数组中的每个变量上执行一个函数.问题是我执行的功能是同一类中的方法.我查看了我的代码,但是找不到问题所在.请让我知道该错误的可能解决方案是什么,或者如果您看到我没有看到的内容.
目前,它甚至没有执行功能escape().我特意在状态变量中添加了一个’,因为我希望将其转义,但是并没有这样做.
一些背景知识:这是我正在构建的数据库类,prepare()方法将在执行查询之前帮助转义查询中的变量.我删除了一些与此问题无关的代码.
这就是它给我的结果:UPDATE table_name SET status =’我做得很好!用户名=“某人”
class Database {
var $weak_escape = false;
function escape($str) {
if ($this->weak_escape) return $this->weak_escape($str);
else return $this->sql_escape($str);
}
function weak_escape($str) {
return addslashes($str);
}
function sql_escape($str) {
return mysql_real_escape_string($str);
}
function prepare($query) {
$args = func_get_args();
array_shift($args);
array_walk($args, array(&$this, 'escape'));
return vsprintf($query, $args);
}
}
$db = new Database();
$username = "someone";
$status = "I'm doing good!";
echo $db->prepare("UPDATE table_name SET status='%s' WHERE username='%s'", $status, $username);
?>
解决方法:
您需要修改参数(array-item的引用),如果返回它,则不会完成:
function escape(&$str)
{
$str=addslashes($str);
}
标签:php,class
来源: https://codeday.me/bug/20191102/1993074.html