Форум программистов, компьютерный форум, киберфорум
PHP
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/4: Рейтинг темы: голосов - 4, средняя оценка - 5.00
0 / 0 / 0
Регистрация: 05.06.2016
Сообщений: 72

Использование текущего айди из сессии

20.05.2019, 13:57. Показов 936. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Пишу интернет-магазин, делаю историю покупок для пользователя в его личном кабинете

Проверяет наличие пользователя в сессии
PHP
1
2
3
4
5
6
7
8
9
    public static function checkLogged()
    {
 
        if (isset($_SESSION['user'])) {
            return $_SESSION['user'];
        }
 
        header("Location: /user/login");
    }
Беру айди этого пользователя
PHP
1
2
3
4
5
6
7
8
9
10
11
12
   
 public function actionHistory()
    {
 
        $id = User::checkLogged();
 
 
        $historyList = History::getOrderHistoryById($id);
 
 
        require_once(ROOT . '/views/cabinet/history.php');
        return true;

Хочу вывести именно его историю заказов
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
    public static function getOrderHistoryById($id)
    {
        echo $id;
 
        $db = Db::getConnection();
 
        $result = $db->query('SELECT user_name, user_phone, date, status FROM product_order WHERE id = :id');
        $historyList = array();
        $i = 0;
 
        while ($row = $result->fetch()) {
            $historyList[$i]['user_name'] = $row['user_name'];
            $historyList[$i]['user_phone'] = $row['user_phone'];
            $historyList[$i]['date'] = $row['date'];
            $historyList[$i]['status'] = $row['status'];
            $i++;
        }
        
        return $historyList;
    }
Но вылазит вот такая ошибка, всю голову сломала
1
Fatal error: Uncaught Error: Call to a member function fetch() on boolean in C:\Users\ASUS\Downloads\OSPanel\domains\ enter\models\History.php:20 Stack trace: #0 C:\Users\ASUS\Downloads\OSPanel\domains\ enter\controllers\CabinetController.php( 75): History::getOrderHistoryById('1') #1 C:\Users\ASUS\Downloads\OSPanel\domains\ enter\components\Router.php(80): CabinetController->actionHistory() #2 C:\Users\ASUS\Downloads\OSPanel\domains\ enter\index.php(18): Router->run() #3 {main} thrown in C:\Users\ASUS\Downloads\OSPanel\domains\ enter\models\History.php on line 20

Проверяю айди, всё правильно, видит нужный, если в запросе напишу конкретный айди, тоже всё правильно выводит, так в чём ошибка? как мне использовать текущий айди из сессии?
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
20.05.2019, 13:57
Ответы с готовыми решениями:

Как можно сравнивать айди в адресной строке с айди в php коде
у меня адресная строка вида: site.com/questions.php?question=6, как сравнивать question=6, чтобы выводить определённую информацию,...

Как айфон снять с айди если забыл предыдущий айди?
Как айфон снять с айди если забыл предедуший айди

Как при отправке формы добавить текущего пользователя сессии в таблицу данных формы
вывод логина юзера, может поможет <?php <?php // Проверяем, пусты ли переменные логина и id пользователя if...

5
Эксперт PHP
3899 / 3237 / 1353
Регистрация: 01.08.2012
Сообщений: 10,909
20.05.2019, 14:06
Может надо $id в query передать?
0
0 / 0 / 0
Регистрация: 05.06.2016
Сообщений: 72
20.05.2019, 14:09  [ТС]
Я что-то путаю?
WHERE id = :id - здесь я не то делаю?
0
Эксперт PHP
3899 / 3237 / 1353
Регистрация: 01.08.2012
Сообщений: 10,909
20.05.2019, 14:14
FantazerMasha, :id - это название плейсхолдера, а нужно же ещё само значение передать.

Если getConnection возвращает объект PDO, то смотрите метод bindValue в документации.
0
0 / 0 / 0
Регистрация: 05.06.2016
Сообщений: 72
20.05.2019, 15:56  [ТС]
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
    public function actionHistory()
    {
 
        $id = User::checkLogged();
 
        
 
        $history = History::getOrderHistoryById($id);
 
 
        require_once(ROOT . '/views/cabinet/history.php');
        return true;
 
    }
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
    public static function getOrderHistoryById($id)
    {
 
        $db = Db::getConnection();
 
        $result = $db->prepare('SELECT user_name, user_phone, date FROM product_order WHERE id = :id');
 
        $result->bindParam(':id', $id, PDO::PARAM_INT);
        
        $result->setFetchMode(PDO::FETCH_ASSOC);
 
        $result->execute();
        
    }
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
            <table class="table-bordered table-striped table">
                <tr>
                    <th>ID заказа</th>
                    <th>Имя покупателя</th>
                    <th>Телефон покупателя</th>
                    <th>Дата оформления</th>
                    <th>Статус</th>
 
                </tr>
                
 
                    <tr>
                        <td>
                            </a>
                        </td>
                        <td><?php echo $history['user_name']; ?></td>
                        <td><?php echo $history['user_phone']; ?></td>
                        <td><?php echo $history['date']; ?></td>
 
                    </tr>
 
            </table>
Что не так теперь? выводит пустую таблицу

Добавлено через 16 минут
Так, не дописала return, всё работает, но выводит почему-то один заказ, а не все

Добавлено через 16 минут
как мне записать это в цикл подскажите пожалуйста?
0
Эксперт PHP
3899 / 3237 / 1353
Регистрация: 01.08.2012
Сообщений: 10,909
20.05.2019, 21:13
FantazerMasha, 2 варианта:
1. Получаем данные в виде массива с помощью fetchAll и подставляем в цикл.
2. Запускаем fetch в цикле.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
20.05.2019, 21:13
Помогаю со студенческими работами здесь

Использование сессии
Здравствуйте. Есть страница с регистрацией пользователя (reg.php), на которой есть форма. Action у формы:...

Использование текущего значения переменной в имени рисунка
Здравствуйте. Решил освоить VB. Практикуюсь потихоньку. Столкнулся со следующим вопросом: На форме (Form1) имеется некоторое количество...

Использование сессии Session в HttpModule
вот есть такая замечательная ссылка http://www.aspnetresources.com/blog/count_your_visitors.aspx, где автор объясняет как при помощи...

Использование текущего значения столбца основного запроса в подзапросе
Переношу данные из одной БД в другую. Схемы разные. Есть запрос по переносу данных: INSERT INTO DB1.dbo.PARTICIPANTS...

Использование класса сессии вне контроллера
Нужно использовать HttpSessionStateBase в классе. В контроллере это метод Session. Никак не могу его правильно инициализировать. По сути,...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru