我的数据库表1行看起来像
我将在body中使用的所有变量存储在名为vars
的另一列中。然后获取所有变量。如果它们是多个,则按“,”符号爆炸。
我想要做的是,从db获取所有使用过的变量,然后通过第二个函数filter
过滤它们。如您所见,过滤器有3个输入:$content, $needle, $replacement
。
$ content - 邮件正文,
$ needle - %
。我们正在搜索的内容。%
$ replacement - 是我们从数据库获得的var,由php定义。例如,如果我从数据库获得wsurl,它已经在我的settings.php中定义,如DEFINE(“wsurl”,“www.yourdomain.com”)。
问题是,如何将定义的值作为第三个输入发送 - $replacement
?
public function genMsg($id) {
$msgid = $id;
$stmt = $db->prepare('SELECT `body`, `status`, `vars` FROM `messages` WHERE `id`=?') or die(htmlspecialchars($this->db->error));
$stmt->bind_param("i", $msgid) or die(htmlspecialchars($stmt->error));
$stmt->execute() or die(htmlspecialchars($stmt->error));
$stmt->bind_result($message, $status, $vars) or die($stmt->error);
$stmt->fetch() or die($stmt->error);
$stmt->close();
$image = ($status == -1) ? "fail" : "success";
if (isset($vars) && !empty($vars)) {
if (strpos($vars, ",")) {
$vars = explode(",", $vars);
foreach ($vars as $key => $var) {
$this->filter($message, $var, <HERE MUST BE DEFINED VALUE>);
}
} else {
$var = trim($vars);
$this->filter($message, $var, <HERE MUST BE DEFINED VALUE>);
}
}
$data = array(
'status' => $status,
'message' => $message
);
}
protected function filter($content, $needle, $replacement) {
return str_replace("%'.$needle.'%", $replacement, $content);
}
答案 0 :(得分:14)
如果我的问题是对的。 这应该有所帮助。
<?php
define('TEST', 'abc');
echo constant('TEST');