Я начал использовать скрипт Tutis для входа. Я внес некоторые изменения, но следующее дает мне ошибки:
Я хочу перечислить всех зарегистрированных пользователей, но цикл по каждому элементу не работает.
Я создал новую функцию в member.class.php:
// Registered Users
public function rusers()
{
global $database;
$notice = new notice;
$users = $database->query('SELECT id, username, date FROM users');
$return_form = 1;
$user = "<table>"
. "<tr>"
. "<td>ID</td>"
. "<td>UserName</td>"
. "<td>Date</td>"
. "</tr>";
// Function in the database.class.php
$result = $database->foreachloop($users);
foreach ($result as $row)
{
$user.= "<tr><td>".$row['id']."</td>";
$user.= "<td>".$row['username']."</td><td>".$row['date']."</td></tr>";
}
$user.= "</table>";
/* Combine Data */
$data = "";
/* Do we need the login form? */
if ($return_form == 1)
{
$data .= $user;
}
/* Return data */
return $notice->report() . $data;
}
И добавил функцию foreachloop() в файл database.class.php.
public function foreachloop($result)
{
return $this->statement->fetch(PDO::FETCH_ASSOC);
}
Но я получаю следующую длинную ошибку:
*Warning: Illegal string offset 'id' in C:\wamp\www\loginoop3\assets\member.class.php on line 996
Warning: Illegal string offset 'username' in C:\wamp\www\loginoop3\assets\member.class.php on line 997
Warning: Illegal string offset 'date' in C:\wamp\www\loginoop3\assets\member.class.php on line 997
Warning: Illegal string offset 'id' in C:\wamp\www\loginoop3\assets\member.class.php on line 996
Warning: Illegal string offset 'username' in C:\wamp\www\loginoop3\assets\member.class.php on line 997
Warning: Illegal string offset 'date' in C:\wamp\www\loginoop3\assets\member.class.php on line 997*
И вывод:
*ID UserName Date
t t t
2 2 2*
Здесь цифра 2 означает идентификатор пользователя, а буква «t» - это «тестовое» имя пользователя, но показывает только первую букву... И показывает только одного пользователя, но есть и другие пользователи.
Я не знаю, что случилось. Есть ли у кого-нибудь предложение?
Этот логин использует OOP PDO. И я попытался внести эти изменения с помощью rowCount(), поскольку в файле database.class.php появилась новая функция со следующим содержимым:
public function affected($result)
{
return $this->statement->rowCount();
}