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

ошибка функции

08.10.2016, 21:49. Показов 846. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Нужна помощь! Пользователь зарегистрировался и подтвердил регистрацию. ПРОБЛЕМА при вводе логин и пароль пишет "неправильный логин или пароль." Из-за чего не пойму.

PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
<?php          
 
function db ($host,$user,$pass,$db_name) {
       $db = mysql_connect($host,$user,$pass);
       if (!$db) {
           exit (mysql_error ());
       }
       
       if(!mysql_select_db($db_name,$db)) {
           exit (mysql_error ());
       }
       mysql_query ("SET NAMES UTF8");
    }
    
    function clear_str($str) {        /*убираем лишние пробелы ненужные теги*/
        return trim(strip_tags($str));
    }
    
    
    function render ($path,$param = array()) {
        extract ($param);
        
        ob_start();
        
        if(!include($path. ".php")) {
            exit ("Нет такого шаблона");            
        }
        
        return ob_get_clean();      
    }
 
    function registration ($post) {
        
        $login = clear_str ($post['reg_login']);
        $number = clear_str ($post['reg_number']);
        $password = trim ($post['reg_password']);
        $conf_pass= trim ($post['reg_password_confirm']);
        $email = clear_str ($post['reg_email']);
        $name = clear_str ($post['reg_name']);
        
        $msg = '';
        
        if(empty($login)) {
            $msg .= "Введите логин <br />";
        }
        if(empty($name)) {
            $msg .= "Введите имя <br />";
        }                   
        if(empty($number)) {
            $msg .= "Введите номер телефона <br />";
        }   
        if(empty($email)) {
            $msg .= "Введите электронную почту <br />";
        }       
        if(empty($password)) {
            $msg .= "Введите пароль <br />";
        }
        
        
        
        if($msg) {
            $_SESSION['reg']['login'] = $login;
            $_SESSION['reg']['number'] = $number;
            $_SESSION['reg']['email'] = $email;
            $_SESSION['reg']['name'] = $name;
            return $msg;
        }
        
        if ($conf_pass == $password) {
            $sql = "SELECT user_id
                    FROM ".PREF."users
                    WHERE login='%s'";
            $sql = sprintf ($sql,mysql_real_escape_string($login));
            
            $result = mysql_query($sql);
            
            if(mysql_num_rows($result) > 0) {
                $_SESSION['reg']['email'] = $email;
                $_SESSION['reg']['name'] = $name;
                
                return "Пользователь с таким логином уже существует";
            }
            
            $password = md5 ($password);
            $hash = md5 (microtime());
            
            $query = "INSERT INTO ".PREF."users (
                        name,
                        number,
                        email,
                        password,
                        login,
                        hash                      
                        )
                     VALUES (
                       '%s',
                       '%s',
                       '%s',
                       '%s',
                       '%s',
                       '$hash'
                     )";
            $query = sprintf ($query,
                                 mysql_real_escape_string ($name), 
                                 mysql_real_escape_string ($number),
                                 mysql_real_escape_string ($email), 
                                 $password,
                                 mysql_real_escape_string ($login) 
                              );
            $result2 = mysql_query($query);
            
            if(!$result2) {
                $_SESSION['reg']['login'] = $login;
                $_SESSION['reg']['number'] = $number;
                $_SESSION['reg']['email'] = $email;
                $_SESSION['reg']['name'] = $name;
                return "Ошибка при добавлении пользователя в базу данных".mysql_error();              
            }
            else {
                $headers = '';
                $headers .= "From: Admin <admin@mail.ru> \r\n";
                $headers .= "Content-Type: text/plain; charset=utf8";
                
                $tema = "registration";
                
                $mail_body = "Спасибо за регистрацию на сайте. Ваша ссылка для подтверждения
    учётной записи: ".SITE_NAME."?action=registration&hash=".$hash;
            
            
            mail ($email,$tema,$mail_body,$headers);
            
            return TRUE ;
            
        }
            
    }
    else {
        $_SESSION['reg']['login'] = $login;
        $_SESSION['reg']['number'] = $number;
        $_SESSION['reg']['email'] = $email;
        $_SESSION['reg']['name'] = $name;
        return "Вы не правильно подтвердили пароль";
        
    }   
        
}
 
    function confirm() {
        
    $new_hash = clear_str($_GET['hash']);
 
    $query = "UPDATE ".PREF."users  
                SET confirm='1'
                WHERE hash = '%s'
                ";
    $query = sprintf($query,mysql_real_escape_string($new_hash));
 
    $result = mysql_query($query);
 
    if(mysql_affected_rows() == 1) {
        return TRUE;
    }
    else {
         return "Не верный код подтверждения регистрации";
    }
        
}
 
function login($post) {
    
    if(empty($post['login']) || empty($post ['password']))  {
        return "Заполните поля";
}
    $login = clear_str($post['login']);
    $password = md5(trim($post['password']));
    
    $sql = "SELECT user_id,confirm
            FROM ".PREF." users
            WHERE login = '%s'
            AND password = '%s'";
    $sql = sprintf($sql,mysql_real_escape_string($login),$password);
    
    $result = mysql_query($sql);
    
    if(!$result || mysql_num_rows($result) < 1) {       
        return "Не правильный логин или пароль";
    }
    if(mysql_result($result,0, 'confirm') == 0) {
        return "Пользователь с таким логином ещё не подтверждён";
    }
    
    $sess = md5 (microtime());
    
    $sql_update = "UPDATE ".PREF."users SET sess='$sess' WHERE login='%s'";
    $sql_update = sprintf($sql_update,mysql_real_escape_string($login));
    
    if(!mysql_query($sql_update))  {
        return "Ошибка авторизации пользователя";      
    }
    
    $_SESSION['sess'] = $sess;
    
    if($post['member'] == 1)  {
        $time = time() + 10*24*3600;
        
        setcookie('login',$login,$time);
        setcookie('password',$password,$time);
        
    }
    
    return TRUE;
    
}
function logout() {
    unset ($_SESSIN['sess']);
    
    setcookie('login','',time()-3600);
    setcookie('password','',time()-3600);
    
    return TRUE;
}
 
function check_user() {
    
    if(isset ($_SESSIN['sess'])) {
        $sess = $_SESSIN ['sess'];
       
        $sql = "SELECT user_id,name,id_role
                FROM ".PREF." users
                WHERE sess='$sess'";
        $result = mysql_query($sql);
 
        if(!$result || mysql_num_rows($result) < 1) {
            return FALSE;
        }
        
        return mysql_fetch_assoc($result);  
    }
    elseif(isset($_COOKIE['login']) && isset($_COOKIE['password'])) {
        $login = $_COOKIE['login'];
        $password = $_COOKIE['password'];
        
        $sql = "SELECT user_id,name,id_role
                FROM ".PREF."users
                WHERE login='$login'
                AND password='$password'
                AND confirm = '1'";
        $result2 = mysql_query($sql);
        
        if(!$result2 || mysql_num_rows($result2) < 1) {
            return FALSE;
        }
        
        $sess = md5(microtime());
        
        $sql_update = "UPDATE ".PREF."users SET sess='$sess' WHERE login='%s'";
        $sql_update = sprintf ($sql_update,mysql_real_escape_string($login));
        
        if(!mysql_query($sql_update)){
            return "Ошибка авторизации пользователя";
        }
        
        $_SESSION['sess'] = $sess;
        
        return mysql_fetch_assoc($result);
    }
    else {
        return FALSE;
    }
    
}
 
 
 
?>





PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
<?php
 
if (isset ($_POST['login']) && isset($_POST ['password'])) {
    
    $msg = login($_POST);
    
    if($msg === TRUE) {
        header("Location:".$_SERVER['PHP_SELF']);       
    }
    else {
        $_SESSION['msg'] = $msg;
        header("Location:".$_SERVER['PHP_SELF']);
    }
    exit();
    
}
if(isset($_POST['logout']))  {
    $msg = logout();
 
    if ($msg === TRUE)  {
        $_SESSION['msg'] = "Вы вышли из системы";
        header("Location:".$_SERVER['PHP_SELF']);
        exit();
    }   
}
 
 
 
 
 
$content = render(TEMPLATE."login.tpl",array("title"=>"Привет"));
?>



PHP/HTML
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
<h1>Войти</h1>
    <?=$_SESSION ['msg'];?>
    <? unset($_SESSION['msg'])?>
              <div id="login">
                <form method='POST'>
                <fieldset id="inputs">
                    <input id="username" name='login' type="text" placeholder="Логин">   
                    <input id="password" name='password' type="password" placeholder="Пароль">
                </fieldset>
                <lable>Запомнить пароль
                    <input type="checkbox" name='member' value="1">
                </lable>
                <fieldset id="actions">
                   <input type="submit" id="submit" value="ВОЙТИ">
                   <a href="?action=returnpass">Забыли пароль?</a><a href="?action=registration">Регистрация</a>
                </fieldset>
                </form>
                </div>
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
08.10.2016, 21:49
Ответы с готовыми решениями:

А почему ошибка, что функции print и read не определены в функции main()?
Что-то не понимаю. Они определены в заголовочном файле. А подчеркивается красным что нет.... #include &lt;iostream&gt; #include...

Ошибка формирования отчета в СКД: ошибка при попытке вычисления значения агрегатной функции
Решая свою задачку, нарыла формулу, в которой вылазит ошибка. И не могу понять.. Вот формула ВЫБОР КОГДА...

Ошибка в шаблоне функции: "Отсутствуют экземпляры шаблон функции, соответствующие списку аргументов"
#include &lt;iostream&gt; #include &lt;iterator&gt; #include &lt;map&gt; #include &lt;Windows.h&gt; #include &lt;functional&gt; #include &lt;string&gt; #include...

6
 Аватар для Пифагор
2172 / 1655 / 840
Регистрация: 10.01.2015
Сообщений: 5,207
08.10.2016, 21:54
Начиная с 215 строки у Вас ошибка
$_SESSIN вместо $_SESSION.
Возможно, дело в этом.
1
0 / 0 / 0
Регистрация: 25.09.2016
Сообщений: 65
08.10.2016, 22:09  [ТС]
Спасибо за помощь. 3 слова исправил, но ошибка осталась.
0
 Аватар для Пифагор
2172 / 1655 / 840
Регистрация: 10.01.2015
Сообщений: 5,207
08.10.2016, 22:20
Попробуйте поменять 183 строку на
PHP
1
$result = mysql_query($sql) or die(mysql_error());
+ добавьте на всякий случай
PHP
1
echo mysql_num_rows($result)
и смотрите, нет ли ошибок и сколько строк приходит из запроса.

Добавлено через 1 минуту
и перепишите все запросы на mysqli_
mysql устарел.
1
0 / 0 / 0
Регистрация: 25.09.2016
Сообщений: 65
08.10.2016, 22:43  [ТС]
Parse error: syntax error, unexpected T_IF, expecting ',' or ';' in Z:\home\localhost\www\Oleru.ru\functions .php on line 186

Добавлено через 2 минуты
Table 'mess_box.mes_' doesn't exist

Добавлено через 4 минуты
mess_box.mes_' где получается вот это исправить, или откуда это взялось. Ведь таблица у меня mess_box а не mess_box.mes_

Добавлено через 7 минут
та вроде исправилась новая возникла )
0
Warning: Cannot modify header information - headers already sent by (output started at Z:\home\localhost\www\Oleru.ru\functions .php:184) in Z:\home\localhost\www\Oleru.ru\actions\l ogin.php on line 12
0
Фрилансер
Эксперт PythonЭксперт JSЭксперт PHP
 Аватар для Azdeman
1871 / 1362 / 604
Регистрация: 12.01.2011
Сообщений: 5,470
08.10.2016, 22:50
Цитата Сообщение от sadovoimikhail Посмотреть сообщение
Warning: Cannot modify header information - headers already sent by (output started at Z:\home\localhost\www\Oleru.ru\functions .php:184) in Z:\home\localhost\www\Oleru.ru\actions\l ogin.php on line 12
Что означает предупреждение "headers already sent"
1
0 / 0 / 0
Регистрация: 25.09.2016
Сообщений: 65
08.10.2016, 23:09  [ТС]
Всё все ошибки исчезли НО основная так и осталась. "неправильный логин или пароль."

Добавлено через 1 минуту
Ура всё !!!!!!! Спасибо всем за участие))))
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
08.10.2016, 23:09
Помогаю со студенческими работами здесь

Ошибка "Присваивание имени функции вне тела этой функции" при наличии двух одноименных функций в одном контексте
Данный код: type T = class public function F: integer; begin F := 2; end; function F(x:...

График функции и ошибка "Неверное число параметров функции"
Program aaa; Uses GraphABC; Var x,y:integer; Begin For x:=0 to 360 do Begin Y:=Round( sin(x*3,14/180)*100); ...

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

Ошибка в функции
Всем доброго суток, не могу понять где ошибка, помогите: #include &lt;iostream&gt; #define N 4 using namespace std; void sortVib(int...

Ошибка в функции
Добрый день. Пожалуйста подскажите почему не работает функция, вроде с синтаксисом все нормально: function av_pereplata_func...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru