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

Форма регистрации на сайте

07.11.2009, 03:04. Показов 6668. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго времени суток!

Сегодня писал форму регистрации на сайте и столкнулся вот с какой проблемкой,
когда при регистрации ввожу в поле "ИМЯ" русские символы то система отвечает что пользователь с таким именем уже существует, хотя в БД такого пользователя нет, с латинским же алфавитом проблем нет никаких.
Данные других полей с русским текстом в БД отображаются в виде каракулей.

вот код файла register.php:

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
<?php
session_start();
 
@include("config.inc.php");
@include("functions.inc.php");
 //Необходимо подключиться к БД
$link = mysql_connect($DBSERVER, $DBUSER, $DBPASS)
or die("Не могу подключиться" );
// сделать $DB текущей базой данных
mysql_select_db($DB, $link) or die ('Не могу выбрать БД');
 
   mysql_query("SET NAMES 'utf8'");
if(!$_POST['do'] OR $_POST['do'] =='') {
 
 
 
//Выводим форму
echo '
<html><head><title>Регистрация</title></head><body>
<form action="" method="POST">
<table width="27%" border="2" cellspacing="1" bordercolor="#0ff00f">
 <tr>
  <td width="40%">Имя:</td><td><input name="name" type="text" value=""></td>
 </tr>
 <tr>
  <td width="40%">Пароль:</td><td><input name="pass" type="password" value=""></td>
 </tr>
 <tr>
  <td width="40%">Повтор пароля:</td><td><input name="rpass" type="password" value=""></td>
 </tr>
 
 <tr>
  <td width="40%">E-Mail</td><td><input name="mail" type="text" value=""></td>
 </tr>
 
 <tr>
  <td width="40%">Код с картинки: *</td><td><input name="keystring" type="text" value=""></td>
 </tr>
 
 <tr>
  <td width="40%"></td><td><img src="image.php?<?php echo session_name()?>=<?php echo session_id()?>"></td>
 </tr>
 
 
 <tr>
  <td width="20%"></td><td><input name="do" type="submit" value="зарегистрировать"></td>
 </tr>
</table>
</form></body></html>';
 
}
 
 
 
 
//Если данные отправлены
if($_POST['do'] !='') {
        //Начинаем проверять входящие данные
        if ($_SESSION['captcha_keystring'] == $_POST['keystring']) {
 
        //Создаем запрос к базе для проверки существования Пользователя
 
        $name = $_POST['name'];
        mysql_query("SELECT * FROM job_users WHERE name='".strtolower($name)."'");
 
        //Проверка результата запроса
 
                if(mysql_affected_rows()==0) {
                    //Проверка ввведенных паролей
 
                    if($_POST['pass'] !='' AND $_POST['rpass'] !='' AND $_POST['pass'] === $_POST['rpass']){
                    //Проверяем на валидность электронный адрес
                            if(checkmail($_POST['mail']) !== -1) {
 
                                //Осуществляем регистарацию
                                //Генерируем uniq_id
                                $uniq_id = md5($_SERVER['REMOTE_ADDR'].$_SERVER['HTTP_USER_AGENT'].mktime());
                                $pass = $_POST['pass'];
                                $email = $_POST['mail'];
                                $city = "Москва";
                                $surname = "Иванов";
                                //Создаем запрос для записи данных в БД
                                $r = @mysql_query("INSERT INTO job_users VALUES(NULL,'".$name."','".$surname."','".md5($pass)."','".$email."','".$city."','".$uniq_id."',0,'".date("dmY")."','".date("dmY")."')");
 
                                //После запроса отправляем письмо юзеру, для активации аккаунта
                                                
                                        if($r) {
 
                                        // Для отправки e-mail в виде HTML устанавливаем необходимый mime-тип и кодировку
                                        $headers  = 'MIME-Version: 1.0' . "\r\n";
                                        $headers .= 'Content-type: text/html; charset=windows-1251' . "\r\n";
 
                                        // Откуда пришло
                                        $headers .= 'From:Сайт %sitename%' . "\r\n";
 
                                        //Здесь укажите электронный адрес, куда будут уходить сообщения
                                        $mailto = $email;
                                        $subject = "Подтверждение регистарции на сайте";
                                        $message = 'Для активации аккаунта пройдите по следующей ссылке <a href="http://92.63.106.170/job/register.php?activation='.$uniq_id.'" target="_blank">http://92.63.106.170/job/register.php?activation='.$uniq_id.'</a>';
$message .= 'или скопируйте ссылку в окно ввода адреса браузера и нажмите enter.';
 
 
 
                                                //Отправляем сообщение
                                                if(sendmail($mailto,$subject,$message,$headers) !== FALSE) {
                                                echo 'Регистрация завершена, на введеный Вами e-mail было отправлено сообщение для активации аккаунта';
                                                    }
                                                else {echo 'Регистрация невозможна: Повторите запрос позднее';}
                                                 }
                                                else {echo 'Регистрация невозможна: Повторите запрос позднее';}
                                     }
                                     else {echo 'Регистрация невозможна: Электронный адрес должен соответствовать шаблону <b>name@domen.com</b><br/><a
 
href="register.php"/>назад</a>';}
 
             }
             else {echo 'Регистрация невозможна: Введенные пароли не совпадают<br/><a href="register.php"/>назад</a>';}
 
 
           }
           else { echo 'Регистрация невозможна: Пользователь с таким именем уже существует<br/><a href="register.php"/>назад</a>';}
 
 
         session_destroy();
        }
        else { echo 'Регистрация невозможна: код подтверждения введен не верно<br/><a href="register.php"/>назад</a>';}
 
 
 
     }
     //Модуль отвечающий за активацию аккаунта
 
     if($_GET['activation'] AND $_GET['activation']!='') {
 
     $uniq_id = $_GET['activation'];
     //Создаем запрос
     $r=@mysql_query("UPDATE job_users SET status=1 WHERE uniq_id='".$uniq_id."' AND status=0");
     if($r) {echo '<h2>Ваша учетная запись активирована.</h2><br/> Теперь вы можете <a href="index.php">войти на сайт</a> используя данные
 
указанные при регистрации';}
 
     else {echo 'Активация невозможна: профиль уже активирован';}
 
     }
?>
Миниатюры
Форма регистрации на сайте  
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
07.11.2009, 03:04
Ответы с готовыми решениями:

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

Форма регистрации
Здравствуйте. Помогите сделать обработчик для формы регистрации на сайт. Не могу разобраться как это правильно делать

Форма регистрации
Всем привет:)! Сделал форму регистрации: &lt;!Doctype html&gt; &lt;html lang=&quot;ru&quot;&gt; &lt;head&gt; &lt;meta http-equiv=&quot;Content-Type&quot;...

8
 Аватар для GalaX
701 / 573 / 59
Регистрация: 18.11.2008
Сообщений: 2,147
07.11.2009, 05:35
попробуй в <head> дописать это:
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
0
365 / 68 / 2
Регистрация: 25.09.2008
Сообщений: 401
07.11.2009, 05:42
по прочтению пхп кода мне непонравилось только:
Code
1
AND $_POST['pass'] === $_POST['rpass']){
а точнее три знака равенства но дело не в этом

предполагаю, что у вас косяк в настройках БД... скорей всего отключена поддержка русского языка или какая-нибудь кривая кодировка используется либо в самой БД исправьте, либо в коде укажите, в какой конкретно кодировке данные БД отправлять...)

ругается на существующее имя, я думаю, по той же причине (может каракули к Null относит или что-то в этом роде)... если разобравшись с кодировкой это не пройдёт, попробуйте повыводить в момент отказа строки, которые нашла БД по запросу на совпадение имён, а не просто проверять их наличие (ругается только на имя потому, что только его вы проверяете на существование в базе, а в остальные поля поэтому пишет каракули...)
0
0 / 0 / 1
Регистрация: 08.11.2008
Сообщений: 86
07.11.2009, 10:52  [ТС]
У меня в бд есть ещё и другие таблицы с которыми нет проблем, а возникли они именно с этой job_users. Я как только не менял кодировку в БД (в опциях таблицы job_users) и на cp1251 и utf8 и др.. но проблему это не решало.
0
0 / 0 / 1
Регистрация: 08.11.2008
Сообщений: 86
07.11.2009, 21:51  [ТС]
Неужели никто не может подсказать в чем может быть ошибка ?))
0
 Аватар для Ceran
172 / 101 / 10
Регистрация: 22.02.2009
Сообщений: 440
07.11.2009, 22:58
Тебе же уже сказали - проблема в кодировке.
0
0 / 0 / 1
Регистрация: 08.11.2008
Сообщений: 86
07.11.2009, 23:24  [ТС]
И что теперь? я тоже знаю что проблема в кодировке а где и как ее менять? Кодировку в БД я менял не раз и это нерашало проблему.
0
 Аватар для GalaX
701 / 573 / 59
Регистрация: 18.11.2008
Сообщений: 2,147
08.11.2009, 05:24
Цитата Сообщение от malik Посмотреть сообщение
Неужели никто не может подсказать в чем может быть ошибка ?))
у тебя при выводе форме не указана кодировка данных, поэтому если сам скрипт в cp1251, то браузер все данные определяет как cp1251, соответственно обратно на сервер данные отправляются тоже в cp1251 (и в базу толкаются в cp1251). а если у тебя кодировка базы в utf, то отсюда и вопросительные знаки.
поменяй кодировку скрипта на utf и в meta укажи кодировку данных:
Цитата Сообщение от GаlаX Посмотреть сообщение
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
т.е. нужно чтоб все было в одной кодировке - база, таблицы, скрипт, html-данные (идущие от браузера)
либо меняй кодировку принудительно перед добавлением в базу, типа такого:
$name = iconv('cp1251', 'utf-8', $_POST['name']);
1
0 / 0 / 1
Регистрация: 08.11.2008
Сообщений: 86
08.11.2009, 14:47  [ТС]
Решение проблемы вставка в head вот этого:
HTML5
1
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
Спасибо GalaX'у
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
08.11.2009, 14:47
Помогаю со студенческими работами здесь

Форма регистрации и авторизации
Доброго времени, подскажите как исправить проблему, голову ломаю - ответа так и не нашел... Буду благодарен за помощь. ...

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

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

Не работает форма регистрации пользователей
Делаю дипломный проект на девере, сайт компьютерного магазина(на PHP). Сейчас делаю формы авторизации и регистрации пользователей. ...

Форма регистрации PHP MYSQL
Всем привет, не могу понять, что не так, обычными словами не могу выразить одни матюки. Сразу по делу. Вот весь код...


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

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
Подключение Box2D v3 к SDL3 для Android: физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
Влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru