我正在Play 2.1里嘗試使用BCrypt實現身份驗證,但我得到了 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]

我的代碼是基於文檔的district.setPassword(BCrypt.hashpw(json.findPath("password").getTextValue(), BCrypt.gensalt()));

用於保存密碼(我還在檢查密碼是否為空),BCrypt.checkpw(password, d.getPassword());

用於檢查輸入的密碼是否正確,其中密碼為字元串,d.getPassword()為散列密碼。

我不知道這是否是相關的信息,但是,為了準確起見,我使用Hibernate作為ORM和PostgreSQL 8.4作為資料庫。

我被困在這裡,所以,是否有人能幫幫我,提前謝謝了

Logo

一站式 AI 云服务平台

更多推荐