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]   

> Описание: CHAR(20) или BINARY(20)
UNTRUSTED
Отправлено: 19 Марта, 2012 - 20:00:30
Post Id


Частый гость


Покинул форум
Сообщений всего: 255
Дата рег-ции: Март 2012  


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




Сначала напишу код
PHP:
скопировать код в буфер обмена
  1. $pass = ...;
  2. $a = sha1($pass,0);//выдаст что-то вроде  2494143b06da3aaeb7892cbb9fd752049a460946
  3. $b = sha1($pass,1); //выдаст что-то вроде n»ЫЄМ+TеK“¬Gf&
  4.  
  5.  

если в базу сохранять $a, то нужно либо BINARY(40) - он сохранит в виде 40 символьного числа, либо CHAR(40), не имеет значения!
Но вот если второй вариант, то тут вообще интересноУлыбка
$b сохраняем в CHAR(20) - сохраняются вот эти каракули, меняем потом в BINARY(20) - получается то число что в $a(тоесть 40 символов умещается в 20 строчной строке, почему??), и обратно меняешь, все норм, совпадает. Тоже самое если сохранять в BINARY(20) сразу...
Вопрос №1:
Можете объяснить, почему тогда первый вариант не записыватся в BINARY(20) а требует 40?
Вопрос №2: Как я понял, лучше использовать с $b? но в какой тип сохранять бинарный или строковый?
Надеюсь понятно расписал help

(Отредактировано автором: 19 Марта, 2012 - 20:02:34)

 
 Top
Мелкий Супермодератор
Отправлено: 19 Марта, 2012 - 20:15:28
Post Id



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


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


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




Разницу между бинарными и символьными данными понимаете? Первая строка представляет собой всего навсего 16-ричный вид второй.

UNTRUSTED пишет:
получается то число что в $a(тоесть 40 символов умещается в 20 строчной строке, почему??)

Получается всё то же самое. Вопрос - что вы выводите? Многие редакторы выводят бинарные данные mysql в том самой 16-виде.


-----
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