BCrypt.checkpw() Исключение недопустимой версии соли

Я пытаюсь реализовать аутентификацию с помощью BCrypt в моей версии 2.1. Java, но я получаю Invalid salt version exception, когда пытаюсь выполнить аутентификацию пользователя.

Это моя трассировка стека

play.api.Application$$anon$1: Execution exception[[IllegalArgumentException: Invalid salt version]]
at play.api.Application$class.handleError(Application.scala:289) ~[play_2.10.jar:2.1.0]
at play.api.DefaultApplication.handleError(Application.scala:383) [play_2.10.jar:2.1.0]
at play.core.server.netty.PlayDefaultUpstreamHandler$$anon$2$$anonfun$handle$1.apply(PlayDefaultUpstreamHandler.scala:132) [play_2.10.jar:2.1.0]
at play.core.server.netty.PlayDefaultUpstreamHandler$$anon$2$$anonfun$handle$1.apply(PlayDefaultUpstreamHandler.scala:128) [play_2.10.jar:2.1.0]
at play.api.libs.concurrent.PlayPromise$$anonfun$extend1$1.apply(Promise.scala:113) [play_2.10.jar:2.1.0]
at play.api.libs.concurrent.PlayPromise$$anonfun$extend1$1.apply(Promise.scala:113) [play_2.10.jar:2.1.0]
java.lang.IllegalArgumentException: Invalid salt version
at org.mindrot.jbcrypt.BCrypt.hashpw(BCrypt.java:664) ~[jbcrypt-0.3m.jar:na]
at org.mindrot.jbcrypt.BCrypt.checkpw(BCrypt.java:763) ~[jbcrypt-0.3m.jar:na]
at model.operations.DistrictOperations.authenticate(DistrictOperations.java:24) ~[na:na]
at controllers.Application.authenticateDistrict(Application.java:26) ~[na:na]
at Routes$$anonfun$routes$1$$anonfun$applyOrElse$2$$anonfun$apply$2.apply(routes_routing.scala:133) ~[na:na]
at Routes$$anonfun$routes$1$$anonfun$applyOrElse$2$$anonfun$apply$2.apply(routes_routing.scala:133) ~[na:na]

Я использую следующий репозиторий maven: http://mvnrepository.com/artifact/org.mindrot/jbcrypt/0.3m

Мой код основан на документации, таким образом

district.setPassword(BCrypt.hashpw(json.findPath("password").getTextValue(), BCrypt.gensalt()));    

Для сохранения пароля (я также проверяю пароль на нуль)

BCrypt.checkpw(password, d.getPassword());

Для проверки правильности введенного пароля, где пароль - String, а d.getPassword() - хешированный пароль.

Я не знаю, является ли это релевантной информацией, но, если быть точным, я использую hibernate для ORM и PostgreSQL 8.4 как DB.

Я как бы застрял здесь, поэтому я спрашиваю, может ли кто-нибудь помочь мне. Чем вы очень заблаговременно.

Ответ 1

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

Ответ 2

Для других, сталкивающихся с одним и тем же исключением, убедитесь, что у вас есть параметры BCrypt.checkpw в правильном направлении. (Я не нашел и, следовательно, нашел этот вопрос, прежде чем понял свою глупую ошибку.)

Или, когда OP ответил сам, запишите/отлажируйте значение хешированного пароля, чтобы проверить, что вы фактически сравниваете хешированный пароль! Это должна быть строка 60 char в формате $2a$10$llw0G6IyibUob8h5XRt9xuRczaGdCm/AiV6SSjf5v78XS824EGbh.

Ответ 3

Я столкнулся с той же проблемой; Убедитесь, что ваш пароль хранится в базе данных в хеш-формате вместо обычного текста. Вот Генератор Bcrypt, чтобы перевести ваш пароль в текстовый пароль в хэширование Bcrypt.

Ответ 4

Вы должны убедиться, что первый аргумент является открытым текстом, а второй - хешированным паролем. Это объявление функции:

 public static boolean checkpw(String plaintext, String hashed)

Ответ 5

BCrypt, кажется, выбрасывает эту красную сельдь, если значение 'hash', которое вы передаете checkpw(password, hash) даже не является дешифруемым значением

Ответ 6

jBcrypt слишком стар и фактически не поддерживается. Пожалуйста, подумайте о переходе на новую реализацию этой библиотеки для обработки новых версий $2y$.

Я решил это, используя эту чистую библиотеку Java https://github.com/patrickfav/bcrypt, добавив ее в свой текущий проект Scala.

С помощью следующей функции я наконец могу проверить хэши, созданные с помощью VERSION_2Y:

  /**
    * Verifies an encrypted password against the expected value
    *
    * @link https://github.com/patrickfav/bcrypt
    * @param hash The hashed password (encypted with BCrypt version $2Y$)
    * @param password The unencrypted password string
    */
  private def verifyBcryptHash(hash: String, password: String): Boolean = {
    if (hash == null || hash.trim.isEmpty)
      false
    else
      BCrypt
        .verifyer()
        .verifyStrict(
          password.toCharArray(),
          hash.toCharArray(),
          BCrypt.Version.VERSION_2Y
        )
        .verified
  }

Ответ 7

У меня та же проблема.

BCrypt.checkpw(password,pw)

В этом случае "пароль" - это "admin", а pw - хешированный пароль. Я получил pw из базы данных и хочу сравнить открытый текст с хешированным текстом. Все, что я получаю, это исключение "java.lang.IllegalArgumentException: недопустимая соль пересмотр".