Форум программистов, компьютерный форум, киберфорум
PHP для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.89/9: Рейтинг темы: голосов - 9, средняя оценка - 4.89
86 / 86 / 30
Регистрация: 12.08.2014
Сообщений: 1,129

Активация аккаунта

15.01.2015, 13:43. Показов 1938. Ответов 14
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем доброго времени суток! Написал функцию, которая позвволяется активировать аккаунт:
PHP
1
2
3
4
5
6
7
8
9
10
    function activate($email, $email_code) {
        $email          = mysql_real_escape_string($email);
        $email_code     = mysql_real_escape_string($email_code);
        if (mysql_result(mysql_query("SELECT COUNT(`user_id`) FROM `users` WHERE `email` = '$email' AND `email_code` = '$email_code' and `activate` = 0"), 0) == 1) {
            mysql_query("UPDATE `users` SET `activate` = 1 WHERE `email` = '$email'");
            return true;
        } else{
            return_false;
        }
    }
То есть, переходя по ссылке,если она верна, то в столбике с активацией вы должны получить вместо нуля единицу. Но, такого не происходит, а вывдается ошибка:
Warning: mysql_result() expects parameter 1 to be resource, boolean given in Z:\home\paskalnikita.com\www\core\functi ons\users.php on line 5. Линия 5 начинается с условия. Подскажите, в чем ошибка? Заранее спасибо!
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
15.01.2015, 13:43
Ответы с готовыми решениями:

Активация аккаунта
Приветствую всех. Решил попрактиковаться в написании сайта с использованием MVC паттерна. В общем за основу взял урок на хабре...

Активация аккаунта
Доброго времени суток. Предположим есть скрипт регистрации, после прохождения отправляется сообщение на мыло для активации, с помощью вот...

Активация аккаунта по email
Не получается настроить код чтобы при нажатие на кнопку "зарегистрироваться" отправлялось сообщение активации на электронную почту. В...

14
 Аватар для Seovin
79 / 79 / 36
Регистрация: 28.02.2014
Сообщений: 400
15.01.2015, 15:47
Цитата Сообщение от paskalnikita Посмотреть сообщение
function activate($email, $email_code)
сюда что передаётся?
0
86 / 86 / 30
Регистрация: 12.08.2014
Сообщений: 1,129
15.01.2015, 16:02  [ТС]
на почту приходит письмо с такой ссылкой
http://pahge.com/activate.php?... 720db6a07e
email_code получаю путем microtime

Добавлено через 7 минут
PHP
1
2
3
4
5
6
7
8
9
if (empty($_POST) === false && empty($errors) === true) {
            $register_data = array(
                'username'      => $_POST['username'],
                'password'      => $_POST['password'],
                'first_name'            => $_POST['first_name'],
                'last_name'     => $_POST['last_name'],
                'email'         => $_POST['email'],
                'email_code'    => md5($_POST['username'] + microtime())
                );
вот так получаю email_code. а сам email из поля при регистрации

Добавлено через 1 минуту
то есть сама ссылка выглядит так:
email($register_data['email'], 'Activate your account',"Hello " .$register_data ['first_name'].",\n\nYou need to activate your account, use the link below : \n\nhttp://page.com/activate.php?email=".$register_data['email']."&email_code=".$register_data['email_code']."\n\n -page.com");
}
0
 Аватар для Seovin
79 / 79 / 36
Регистрация: 28.02.2014
Сообщений: 400
15.01.2015, 16:26
проверьте на ошибки
PHP
1
2
$result = mysql_query("SELECT COUNT(`user_id`) FROM `users` WHERE `email` = '$email' AND `email_code` = '$email_code' and `activate` = 0"), 0) == 1) 
  if(!$result) exit("Ошибка - ".mysql_error());
1
86 / 86 / 30
Регистрация: 12.08.2014
Сообщений: 1,129
15.01.2015, 16:33  [ТС]
Parse error: syntax error, unexpected ',' in
Цитата Сообщение от Seovin Посмотреть сообщение
$result = mysql_query("SELECT COUNT(`user_id`) FROM `users` WHERE `email` = '$email' AND `email_code` = '$email_code' and `activate` = 0"), 0) == 1) if(!$result) exit("Ошибка - ".mysql_error());
0
 Аватар для Seovin
79 / 79 / 36
Регистрация: 28.02.2014
Сообщений: 400
15.01.2015, 16:36
paskalnikita, теперь понятно?
0
86 / 86 / 30
Регистрация: 12.08.2014
Сообщений: 1,129
15.01.2015, 17:11  [ТС]
нет)

Добавлено через 49 секунд
Цитата Сообщение от paskalnikita Посмотреть сообщение
if (mysql_result(mysql_query("SELECT COUNT(`user_id`) FROM `users` WHERE `email` = '$email' AND `email_code` = '$email_code' and `activate` = 0"), 0) == 1) {
как тогда с этим по-другому ?

Добавлено через 2 минуты
Ваш код
Цитата Сообщение от Seovin Посмотреть сообщение
$result = mysql_query("SELECT COUNT(`user_id`) FROM `users` WHERE `email` = '$email' AND `email_code` = '$email_code' and `activate` = 0"), 0) == 1) if(!$result) exit("Ошибка - ".mysql_error());
я подставляю вместо
Цитата Сообщение от paskalnikita Посмотреть сообщение
if (mysql_result(mysql_query("SELECT COUNT(`user_id`) FROM `users` WHERE `email` = '$email' AND `email_code` = '$email_code' and `activate` = 0"), 0) == 1) { mysql_query("UPDATE `users` SET `activate` = 1 WHERE `email` = '$email'"); return true; } else{ return_false; }
в функции

Добавлено через 27 минут
в чем ошибка, скажите, не понимаю.

Добавлено через 33 секунды
может нужно "Больше кода!"
0
 Аватар для Seovin
79 / 79 / 36
Регистрация: 28.02.2014
Сообщений: 400
15.01.2015, 17:44

Не по теме:

сорри скопировал ваш код и не пригляделся



Добавлено через 11 минут
Цитата Сообщение от paskalnikita Посмотреть сообщение
SELECT COUNT(`user_id`)
а зачем считать? чет не могу понять,
переходит по ссылке на стр. активкод.пхп там функция
email_code и email вам надо доставать из масива $register_data[], нет из ссылки да.
потом сверяем есть ли в базе записи с такими email_code и email и `activate` = 0 если да то получаем 1
а зачем
Цитата Сообщение от paskalnikita Посмотреть сообщение
SELECT COUNT(`user_id`)
1
86 / 86 / 30
Регистрация: 12.08.2014
Сообщений: 1,129
15.01.2015, 17:52  [ТС]
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
    if (isset($_GET['success']) === ture && empty($_GET['success']) === true) {
    ?>
        <h2>Thanks, you activated your accaount...</h2>
        <p>You are free to log in</p>
    <?php
    } else if (isset($_GET['email'], $_GET['email_code']) === true) {
        $email      = trim($_GET['email']);
        $email_code     = trim($_GET['email_code']);
 
 
        if (email_exists($email) === false) {
            $errors[] = 'We couldnt find your email';
        } else if (activate($email, $email_code) === false) {
            $errors = 'We had problems activating your account';
        }
вот код активации, где и ест функция activate
PHP
1
2
3
4
5
6
7
8
9
10
    function activate($email, $email_code) {
        $email          = mysql_real_escape_string($email);
        $email_code     = mysql_real_escape_string($email_code);
        if (mysql_result(mysql_query("SELECT `user_id` FROM `users` WHERE `email` = '$email' AND `email_code` = '$email_code' and `activate` = 0"), 0) == 1) {
            mysql_query("UPDATE `users` SET `activate` = 1 WHERE `email` = '$email'");
            return true;
        } else{
            return_false;
        }
    }
исправил, та как Вы предложили, но нет, та же ошибка )

Добавлено через 22 секунды
COUNT убрал, но это ничего не изменило

Добавлено через 1 минуту
на страницу с success я попадаю, когда перехожу по ссылке, которую писал ранее, и если там email и mail_code совпадают с ними , но в бд, то идет на страницу с success
0
 Аватар для Seovin
79 / 79 / 36
Регистрация: 28.02.2014
Сообщений: 400
15.01.2015, 18:06
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
 function activate($email, $email_code) {
        $email          = mysql_real_escape_string($email);
        $email_code     = mysql_real_escape_string($email_code);
        $id = mysql_query("SELECT `user_id` FROM `users` WHERE `email` = '$email' AND `email_code` = '$email_code' and `activate` = 0");
       $res = mysql_fetch_array($id);
      $user_id = $res[user_id];
       if(mysql_result($id)) {
            mysql_query("UPDATE `users` SET `activate` = 1 WHERE `user_id` = '$user_id");
            return true;
        } else{
            return_false;
        }
    }
типа того
1
86 / 86 / 30
Регистрация: 12.08.2014
Сообщений: 1,129
15.01.2015, 18:12  [ТС]
как бы грустно это не звучало, но ваша реализации функции не работает
0
 Аватар для Seovin
79 / 79 / 36
Регистрация: 28.02.2014
Сообщений: 400
15.01.2015, 18:15
emeil и emeil_code существуют?, выведите их значение
0
86 / 86 / 30
Регистрация: 12.08.2014
Сообщений: 1,129
15.01.2015, 18:21  [ТС]
есть , var_dump ($email); и var_dump($email_code); выводят значение, которые и должны быть. то есть правильный email и email_code
0
 Аватар для Seovin
79 / 79 / 36
Регистрация: 28.02.2014
Сообщений: 400
15.01.2015, 18:29
Лучший ответ Сообщение было отмечено paskalnikita как решение

Решение

PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
function activate($email, $email_code) {
        $email          = mysql_real_escape_string($email);
        $email_code     = mysql_real_escape_string($email_code);
        $id = mysql_query("SELECT `user_id` FROM `users` WHERE `email` = '$email' AND `email_code` = '$email_code' and `activate` = 0");
       $res = mysql_fetch_array($id);
      $user_id = $res[user_id];
       if(mysql_result($id)) {
            mysql_query("UPDATE users SET activate = 1 WHERE user_id = '$user_id");
            return true;
        } else{
            return_false;
        }
    }
пробуем так
ипроверить выборку надо

Не по теме:

поправил

1
86 / 86 / 30
Регистрация: 12.08.2014
Сообщений: 1,129
15.01.2015, 18:34  [ТС]
Вы гений! Спасибо! Наконец-то получилось
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
15.01.2015, 18:34
Помогаю со студенческими работами здесь

Активация Аккаунта по e-mail
Всем, Доброго времени суток. Вот, встала задача, организовать регистрацию пользователей. Регистрация пошаговая. на первом шаге, ...

Верификация аккаунта по смс
Всем доброго времени суток Стоит не лёгкая задача: Есть сервер World of Warcraft, есть страничка с регистрацией аккаунтов Требуеться...

Выход из аккаунта на сессиях
Имеется следующий код: &lt;? session_destroy(); unset($_POST); unset($_POST); ?&gt; &lt;script&gt; function func(){ ...

Создание поддомена для аккаунта
Подскажите, как реализовать, чтобы при регистрации на сайте, автоматически создавался поддомен вида: username.site.ru?

Реферальная система без аккаунта пользователя
Например, человек зашел на страницу (ни какой регистрации на сайте нет) для него сгенерировалась реф. ссылка, и отображается рядом сколько...


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

Или воспользуйтесь поиском по форуму:
15
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru