Как получить определенное значение по переменной

Мои таблицы базы данных 1 строка выглядит так

enter image description here

Я храню все переменные, которые используются в теле, в другом столбце с именем vars . Затем получение всех vars. Если их несколько, с разрывом знаком «,».

Я хочу получить все используемые переменные из базы данных, а затем отфильтровать их с помощью второй функции filter . Как видите, фильтр имеет 3 входа: $ content, $ Need, $ replace .

$ content - тело сообщения,

$ Needle - % . Что мы ищем. %

$ замена - это переменная, полученная нами из базы данных, определенная php. Например, если я получаю wsurl из базы данных, он уже определен в моем settings.php, например DEFINE («wsurl», «www.yourdomain.com»).

Вопрос в том, как я могу отправить определенное значение в качестве третьего ввода - $ replace ?

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);
}
6
задан Brian Tompsett - 汤莱恩 28 November 2015 в 23:52
поделиться