0

我正在尝试使用 squeryl ORM 框架将用户名和加密密码对插入数据库表中。我的代码基本上如下所示:

      class SHA1(e: StringExpression[String], m:OutMapper[String]) extends FunctionNode[String]("sha1", Some(m), Seq(e)) with StringExpression[String]

      def sha1(e:StringExpression[String])(implicit m:OutMapper[String]) = new SHA1(e,m)
      transaction{
        val foo = TestUser.userTable insert User("test@domain.com", sha1("password"))
      }

但这不起作用。我收到一条错误消息:

type mismatch; found : controllers.SHA1 required: String Error occurred in an application involving default arguments. 
4

1 回答 1

1

Squeryl 在这里可以施展的魔法是有限度的。您的模型类接受一个字符串值作为密码,并且您正在向它传递一个 SHA1 类型的值(从 sha1 函数返回的值)。scala 编译器不允许这样做。这里有几个选项:

  1. 在将密码发送到数据库之前对密码进行哈希处理
  2. 使用密码为空值插入您的用户,然后使用通过您的函数散列的密码在同一事务中更新它
  3. 如果您使用的是 Squeryl 0.9.6-SNAPSHOT,您可能会创建一个 SHAString 自定义类型,用于在将字符串发送到数据库时对其进行散列处理

要在插入密码之前对其进行哈希处理,请查看java.security.MessageDigest并查看此答案

于 2013-04-22T15:43:00.877 回答