Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/topic.php on line 737
Форумы портала PHP.SU :: Как хранить пароли пользователей?

 PHP.SU

Программирование на PHP, MySQL и другие веб-технологии
PHP.SU Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


 Страниц (1): [1]   

> Без описания
Rooner
Отправлено: 13 Февраля, 2014 - 12:50:23
Post Id


Посетитель


Покинул форум
Сообщений всего: 291
Дата рег-ции: Авг. 2010  


Помог: 0 раз(а)




В БД хранятся пользователи. Необходимо отправить на почту пользователю его учетные данные: логин и пароль, но пароль закодирован(md5(md5($pass).$res['salt'])). Раскодировать пароль разумеется не вариант. Подскажите как лучше сохранить пароли, чтобы потом у админа к ним был доступ?

(Отредактировано автором: 13 Февраля, 2014 - 12:51:02)

 
 Top
Invert
Отправлено: 13 Февраля, 2014 - 12:52:37
Post Id



Частый гость


Покинул форум
Сообщений всего: 223
Дата рег-ции: Нояб. 2010  


Помог: 5 раз(а)




В БД пароли не должны храниться в открытом виде, вопрос безопасности.

Если хотите иметь доступ к паролям пользователей, то храните в открытом виде, только прочтите еще раз строчку выше.
 
 Top
IllusionMH
Отправлено: 13 Февраля, 2014 - 12:53:44
Post Id



Активный участник


Покинул форум
Сообщений всего: 4254
Дата рег-ции: Февр. 2011  
Откуда: .kh.ua


Помог: 242 раз(а)




Rooner, не хранить пароли ни в коем случае. Генерировать новый пароль автоматом, слать его пользователю и заносить в БД.
 
 Top
teddy
Отправлено: 13 Февраля, 2014 - 12:57:15
Post Id


Участник


Покинул форум
Сообщений всего: 1462
Дата рег-ции: Апр. 2013  


Помог: 91 раз(а)




Rooner
Если нужно хранить исходный пароль пользователя у себя в открытом виде, тогда при регистрации сделайте ещё одну операцию, которая будет логировать для Вас то, что ввел пользователь при регистрации, без применения хеш-функций.

Например пользователь ввел 123 в качестве пароля и мы приняли это в переменную $password. При добавлении в базу $password логируйте для себя(в файл, отправляйте себе на почту и т.д как удобно). А в базу уже записывайте хеш от $password.

И ещё пару моментов: гораздо безопаснее пользоваться функцией crypt() для шифрования паролей, и не хорошо следить за данными пользователя, которые по его мнению, не знает никто Улыбка
 
 Top
Rooner
Отправлено: 13 Февраля, 2014 - 13:04:33
Post Id


Посетитель


Покинул форум
Сообщений всего: 291
Дата рег-ции: Авг. 2010  


Помог: 0 раз(а)




Хм, наверное самый простой вариант это всетаки генерить пароль и отправлять пользователю. Думал, что есть какое-то изящное решение, ну ладно сделаю по простому, спасибо.
 
 Top
Мелкий Супермодератор
Отправлено: 13 Февраля, 2014 - 13:12:24
Post Id



Активный участник


Покинул форум
Сообщений всего: 11926
Дата рег-ции: Июль 2009  
Откуда: Россия, Санкт-Петербург


Помог: 618 раз(а)




Есть так же вариант:
сгенерировать уникальную, ограниченную по времени действия ссылку.
Перейдя по которой возможно изменить пароль этой учётной записи.


-----
PostgreSQL DBA
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« Вопросы новичков »


Все гости форума могут просматривать этот раздел.
Только зарегистрированные пользователи могут создавать новые темы в этом разделе.
Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.
 



Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS  RSS

 
Powered by ExBB FM 1.0 RC1. InvisionExBB