Получение ошибки санации проверки формы данных

Я получаю некоторые ошибки, связанные с очисткой данных форм и выводом этой ошибки, я новичок в этом, поэтому будьте терпеливы с перемещением mysqli в PDO — это новый мир, который я изучаю:

Validate.php

    <?php
class Validate {
private $_passed = false,
$_errors = array(),
$_db = null;

public function __construct() {
$this->_db = DB::getInstance();
}

public function check($source, $items = array()) {
foreach($items as $item => $rules) {
foreach($rules as $rule => $rule_value){

$value = trim($source[$item]);
$item = escape($items);

if($rule === 'required' && empty($value)) {
$this->addError("{$item} is required");

}    else if(!empty($value)){
switch($rule) {
case 'min':
if(strlen($value) < $rule_value) {
$this->addError("{$item} must be a minimum of {$rule_value} characters");
}
break;
case 'max':
if(strlen($value) > $rule_value) {
$this->addError("{$item} must be a maximum of {$rule_value} characters");
}
break;
case 'matches':
if($value != $source[$rule_value]) {
$this->addError("{$rule_value} must match {$item}");
}
break;
case 'unique':
$check = $this->_db->get($rule_value, array('$item', '=', '$value'));
if($check->count()){
$this->addError("{$item} already exists.");
}
break;
}

}

}
}

if(empty($this->_errors)) {
$this->_passed = true;
}

return $this;

}

private function addError($error) {
$this->_errors[] = $error;
}

public function errors() {
return $this->_errors;
}

public function passed() {
return $this->_passed;
}

So here is my sanitize file:

<?php
function escape($string) {
return htmlentities($string, ENT_QOUTES, 'UTF-8');
}

Я получаю эту ошибку, когда я включаю

$item = escape($items);

Предупреждение: htmlentities () ожидает, что параметр 1 будет строкой, а массив задан в …

Та же ошибка, что и при добавлении значения в поле формы, например:

<?php echo Input::get('name'); ?>

Если бы кто-то мог посоветовать лучший метод или посоветовать, где я ошибся, я был бы очень признателен …

0

Решение

Ваша функция используется со строками

попробуй это

замещать $item = escape($items); от $item = escape($value);

С уважением

0

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]