Задать вопрос

Почему не корректно работает функция crypt?

так получилось что достался проект, там пароль кодируется через функцию crypt. Простестировав нашел баг, если это можно так считать.
$salt = substr('test123', 0, 2);

        echo (crypt('testtest123', $salt)).'<br>';
        echo (crypt('testtest', $salt)).'<br>';
        echo (crypt('testtest1', $salt)).'<br>';

у всех троих результат один, то есть если кто то введет пароль testtest или testtest1 у определенного пользователя с паролем testtest123, то он без проблем авторизуется. Это функция криво работает или как?
  • Вопрос задан
  • 77 просмотров
Подписаться 1 Простой Комментировать
Помогут разобраться в теме Все курсы
  • Skillfactory
    Профессия Fullstack веб-разработчик на JavaScript и PHP
    20 месяцев
    Далее
  • Хекслет
    PHP-разработчик
    10 месяцев
    Далее
  • Нетология
    Веб-разработчик с нуля: профессия с выбором специализации
    14 месяцев
    Далее
Решения вопроса 1
Ivanq
@Ivanq
Знаю php, js, html, css
По умолчанию используется алгоритм DES, то есть обрабатываются только первые 8 символов, а они одинаковые.

https://stackoverflow.com/questions/20875703/why-i...

Вместо этого можно использовать соль вида $6$сольиз16символов ($6$ - SHA512).
Ответ написан
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы
FoodSoul Калининград
от 180 000 до 250 000 ₽
IT-Spirit Москва
от 230 000 до 320 000 ₽
от 200 000 до 290 000 ₽