【发布时间】:2016-10-15 18:17:00
【问题描述】:
我正在使用play silhouette 4.0.0-BETA4。除了存储密码外,一切似乎都正常。每次我尝试注册新用户时,都会输入所有详细信息,但密码似乎存储在passwordinfo 表中。
我正在使用 MySQL 数据库。
我花了几个小时试图找出问题所在,但我无法弄清楚。
build.sbt
"com.mohiva" %% "play-silhouette" % "4.0.0-BETA4",
"com.mohiva" %% "play-silhouette-persistence-memory" % "4.0.0-BETA4",
"com.mohiva" %% "play-silhouette-password-bcrypt" % "4.0.0-BETA4",
"com.mohiva" %% "play-silhouette-testkit" % "4.0.0-BETA4" % "test"
注册控制器
val user = User(
None,
userID = UUID.randomUUID(),
loginInfo = loginInfo,
firstName = Some(data.firstName),
lastName = Some(data.lastName),
fullName = Some(data.firstName + " " + data.lastName),
email = Some(data.email),
avatarURL = None
)
for {
avatar <- avatarService.retrieveURL(data.email)
user <- userService.save(user.copy(avatarURL = avatar))
authInfo <- authInfoRepository.add(loginInfo, authInfo)
authenticator <- silhouette.env.authenticatorService.create(loginInfo)
token <- silhouette.env.authenticatorService.init(authenticator)
} yield {
silhouette.env.eventBus.publish(SignUpEvent(user, request))
silhouette.env.eventBus.publish(LoginEvent(user, request))
Ok(Json.obj("token" -> token))
}
这里authInfoRepository.add应该在数据库中添加密码。
我尝试调试authInfoRepository 的add 函数,它似乎让我进入DelegableAuthInfoRepository.scala 中的add 函数。这是函数:
override def add[T <: AuthInfo](loginInfo: LoginInfo, authInfo: T): Future[T] = {
daos.find(_.classTag.runtimeClass == authInfo.getClass) match {
case Some(dao) => dao.asInstanceOf[AuthInfoDAO[T]].add(loginInfo, authInfo)
case _ => throw new ConfigurationException(AddError.format(authInfo.getClass))
}
}
我使用 IntelliJ 评估 daos.find(_.classTag.runtimeClass == authInfo.getClass),它似乎给了我一个我无法理解的错误(错误是:Could not evaluate due to a change in a source file;此错误仅在使用 IntelliJ 评估时出现,日志中没有其他内容)。如果我尝试继续执行,它会转到case Some 行。如果我继续,调试器将返回daos.find 行。我试图从case Some 行检查add 函数的实现,它似乎只找到与内存数据库相关的内容:InMemoryAuthInfoDAO.scala。
我不确定问题是否来自这里,但我真的不明白为什么它没有添加密码并且其他一切都按预期工作。
我使用的代码取自 Silhouette 网站的一些示例。我对安全性了解不多。
如果还有什么遗漏的,请告诉我。
【问题讨论】:
-
“它似乎给了我一个我无法理解的错误”你介意分享一下吗?
-
我将它添加到我的初始帖子中。也在这里
Could not evaluate due to a change in a source file。未对来源进行任何更改。 -
不确定这是否有帮助,但查看一些示例,我发现 DAO 是在配置 DI 期间设置的。也许你没有改变这一点。见github.com/mohiva/play-silhouette-seed/blob/master/app/modules/…
-
我使用了 Angular 种子项目,似乎他们将其更新为更新版本。这是种子:github.com/mohiva/play-silhouette-angular-seed。问题是通过将剪影更新到最新版本并使用完全相同的模块配置(通知
bind[DelegableAuthInfoDAO[PasswordInfo]].toInstance(new InMemoryAuthInfoDAO[PasswordInfo]))我在编译时收到以下错误: -
SilhouetteModule.scala:192: Cannot generate a config value reader for type Option[Option[Seq[com.mohiva.play.silhouette.api.util.RequestPart.Value]]], because value readers cannot be auto-generated for types with type parameters. Consider defining your own ValueReader[Option[Option[Seq[com.mohiva.play.silhouette.api.util.RequestPart.Value]]]]。我使用的最新版本的剪影也有 InMemoryAuthInfo 的实现,这个版本没有。
标签: scala playframework silhouette