Я пытаюсь реализовать аутентификацию с помощью BCrypt в моей версии 2.1. Java, но я получаю Invalid salt version exception
, когда я пытаюсь выполнить аутентификацию пользователя.BCrypt.checkpw() Исключение недопустимой версии соли
Это мой трассировки стека
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() - хешированный пароль.
Я не знаю, является ли это релевантной информацией, но если быть точным, я использую спящий режим для ORM и PostgreSQL 8.4 как DB.
Я как бы застрял здесь, поэтому я спрашиваю, может ли кто-нибудь помочь мне. Чем вы очень заблаговременно.
В частности: соль JBCrypt ожидает соль версии 2a, поэтому соль начинается с $ 2a $. Если вы использовали другую версию BCrypt, в которой используется более современная соляная версия 2y или 2b - JBCrypt выдает исключение. – daphshez