Форум программистов, компьютерный форум, киберфорум
PHP: базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.80/5: Рейтинг темы: голосов - 5, средняя оценка - 4.80
1 / 1 / 0
Регистрация: 02.06.2013
Сообщений: 83

Восстановление пароля, не работает скрипт

18.08.2013, 15:49. Показов 1074. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый День! Пишу скрипт, который задаст пользователю секретный вопрос, по указанному E-mail. Мой скрипт верно определяет, что такого адреса в базе нет, однако, если указать правильный адрес - выдает null. В чем ошибка?
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
<?php
$email = $_GET[email]; 
$link = mysqli_connect('localhost','root','','basename');
    mysqli_query($link, "set character_set_client='utf8'");
    mysqli_query($link, "set character_set_results='utf8'");
    mysqli_query($link, "set collation_connection='utf8_general_ci'");
if(mysqli_connect_errno()) die('Ошибка соединения: '.mysqli_connect_error()); 
else { 
    $res = mysqli_query($link,"SELECT `secquestion` FROM `users` WHERE `email` = '$email'");
    if($res) {
    if (count(mysqli_fetch_assoc($res)) == 1){
$row = mysqli_fetch_assoc($res);
$question = $row[secquestion];
}
else{
    $question = "Указан непраильный E-mail адрес";
}
mysqli_free_result($res); //очищаем занятую память - она уже не нужна
}
}
mysqli_close($link);
echo json_encode(array("0" => $question));  
?>
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
18.08.2013, 15:49
Ответы с готовыми решениями:

Не работает восстановление пароля по мылу
Написал скрипт для восстановления пароля по мылу и логину, но он либо не работает, либо работает, но не так как хотелось бы. Ошибок не...

Восстановление пароля
Доброго времени суток! Совсем недавно я писал здесь по поводу регистрации. Получив очень много замечаний, и узнав множество ошибок в моем...

Восстановление пароля
Доброе время суток всем! Моя про блема состоит в том, что не происходит изменение данных в БД. Запрос выполняется и генирирование нового...

4
Почетный модератор
Эксперт HTML/CSSЭксперт PHP
 Аватар для KOPOJI
16844 / 6724 / 880
Регистрация: 12.06.2012
Сообщений: 19,967
18.08.2013, 15:57
Ну правильно.
Цитата Сообщение от Dimka_nevidimka Посмотреть сообщение
PHP
1
if (count(mysqli_fetch_assoc($res)) == 1){
взяли яблоко, если оно есть, и выкинули.
..а затем пытаемся взять тоже самое яблоко
Цитата Сообщение от Dimka_nevidimka Посмотреть сообщение
PHP
1
$row = mysqli_fetch_assoc($res);
1
1 / 1 / 0
Регистрация: 02.06.2013
Сообщений: 83
18.08.2013, 18:24  [ТС]
Цитата Сообщение от KOPOJI Посмотреть сообщение
Ну правильно.

взяли яблоко, если оно есть, и выкинули.
Почему выкинули?
0
Почетный модератор
Эксперт HTML/CSSЭксперт PHP
 Аватар для KOPOJI
16844 / 6724 / 880
Регистрация: 12.06.2012
Сообщений: 19,967
18.08.2013, 18:37
я ж откуда знаю, почему вы его выкинули
Fetch-функции возвращают данные из следующей строки БД (если по-простому). Иначе NULL/FALSE. Вот и получается, что вы взяли один ряд, проверили, есть ли там что-то, и забыли про него. А в это время указатель сдвинулся на следующий результат запроса. Т.к. его нет (ведь результат - только одна строчка) - то в ответ вы ничего и не получаете. Вернее получаете, но NULL. Ну и нотайс, но вы их не видите, т.к. они скрыты по умолчанию.
1
1 / 1 / 0
Регистрация: 02.06.2013
Сообщений: 83
18.08.2013, 18:49  [ТС]
Цитата Сообщение от KOPOJI Посмотреть сообщение
я ж откуда знаю, почему вы его выкинули
Fetch-функции возвращают данные из следующей строки БД (если по-простому). Иначе NULL/FALSE. Вот и получается, что вы взяли один ряд, проверили, есть ли там что-то, и забыли про него. А в это время указатель сдвинулся на следующий результат запроса. Т.к. его нет (ведь результат - только одна строчка) - то в ответ вы ничего и не получаете. Вернее получаете, но NULL. Ну и нотайс, но вы их не видите, т.к. они скрыты по умолчанию.
Спасибо, проблему решил, по другому себе представлял работу fetch-функции
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
18.08.2013, 18:49
Помогаю со студенческими работами здесь

Восстановление пароля
Тут проблема, потерял пароль от подключения к инету, интернет проводной, обратиться к провайдеру нет возможности, нашел в инете где...

Восстановление пароля
Всем привет, хочу сделать восстановление пароля. Проблема с отправкой письма на почту. Пробовал способы указанные на разных бортах, ничего...

Восстановление пароля
Доброе время суток форумчане. Имеется форма восстановления пароля, но по какой то причине она не отправляется. Т.е на хостинге пишет в...

Восстановление пароля БД
Добрый день, у нас в организации поругался с начальством и уволился программист, у которого была самодельная программа (ее кстати он забрал...

Восстановление пароля от Wi-Fi
Доброго времени суток всем. Перейду прямо к делу. Есть дома комп. подключённый к Wi-Fi. Пароль забыт. Хочется и через мобильный...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru