Play Framework:错误类型不匹配;发现:需要Int:play.api.mvc.Result

时间:2015-01-27 15:27:09

标签: scala playframework playframework-2.3 scala-2.11

我正在尝试将表单值保存到数据库,然后播放我收到错误:

type mismatch;  found :Int required: play.api.mvc.Result 

这是我的代码:

Application.scala

import play.api._
import play.api.mvc._
import play.api.data._
import play.api.data.Forms._
import views.html.defaultpages.badRequest
import play.api.data.validation.Constraints._    
import models.User
import models.UserData    

object Application extends Controller {

   val RegisterForm = Form(
      mapping(     
         "fname" -> nonEmptyText(1, 20),
         "lname" -> nonEmptyText(1, 20),
         "email" -> email,
         "userName" -> nonEmptyText(1, 20),
         "password" -> nonEmptyText(1, 20),
         "age" -> number,
         "choice" -> text,
         "gender" -> text
      )(User.apply)(User.unapply)
       .verifying("Ag should be greater then or equal to 18", model => model.age match {
          case (age) => age >= 18
       })
  )

  def index = Action {
    Ok(views.html.index(RegisterForm))
  }

  def register = Action { implicit request => 
      RegisterForm.bindFromRequest().fold(
          hasErrors => BadRequest(views.html.index(hasErrors)), 
          success => {  
              User.save(success)
          }
      )
  }

}

User.scala

import anorm._
import play.api.db.DB
import anorm.SqlParser._
import play.api.Play.current

case class User (
  fname: String,
  lname: String,
  email: String,
  userName: String,
  password: String,
  age: Int,
  choice: String,
  gender: String
)

object User {

  val userinfo = {
    get[String]("fname") ~ 
    get[String]("lname") ~ 
    get[String]("email") ~ 
    get[String]("userName") ~ 
    get[String]("password") ~ 
    get[Int]("age") ~ 
    get[String]("choice") ~ 
    get[String]("gender") map {
        case fname~lname~email~userName~password~age~choice~gender => 
            User(fname, lname, email, userName, password, age, choice, gender)
        }
    }

  def save(ud: User) = {
     DB.withConnection { implicit c => 
         SQL ("insert into userinfo(fname,lname,email,userName,password,age,choice,gender) values ({fname},{lname},{email},{userName},{password},{age},{choice},{gender})")
         .on('fname -> ud.fname, 'lname ->ud.lname ,'email ->ud.email, 'userName->ud.userName , 'password->ud.password ,'age->ud.age, 'choice->ud.choice,'gender->ud.gender)
         .executeUpdate()  
     }
  }

}

我从scala烹饪书中获取了这个保存功能的帮助,但是我遇到了问题,因为我是新玩的scala也许错误是次要的,所以请帮助我,我想要的只是将所有输入值存储在DB中以表格

输入

2 个答案:

答案 0 :(得分:3)

问题在于您的控制器功能register

def register = Action { implicit request => 
    RegisterForm.bindFromRequest().fold(
       hasErrors => BadRequest(views.html.index(hasErrors)), 
       success => {
           // You need to return a `Result` here..
           // Maybe redirect to login?
           // Redirect("/login")
           User.save(success)
       }
    )
}

问题是User.save返回Int,控制器功能期待Result,例如Ok(..)Redirect(...)等。您需要使用User.save的结果执行某项操作以返回Result

如果您使用executeInsert()代替executeUpdate()会更好,因为executeInsert默认返回Option[Long] - 这将有助于您确定保存是否成功。

e.g:

def save(ud: User): Option[Long] = {
    DB.withConnection {implicit c => 
        SQL("insert into userinfo(fname,lname,email,userName,password,age,choice,gender) values ({fname},{lname},{email},{userName},{password},{age},{choice},{gender})")
            .on('fname -> ud.fname, 'lname ->ud.lname ,'email ->ud.email, 'userName->ud.userName , 'password->ud.password ,'age->ud.age, 'choice->ud.choice,'gender->ud.gender)
            .executeInsert()  
    }
}

然后在你的控制器功能中使用它:

def register = Action { implicit request => 
    RegisterForm.bindFromRequest().fold(
       hasErrors => BadRequest(views.html.index(hasErrors)), 
       success => {
           User.save(success) map { newId =>
               Redirect("/login") // or whatever you want this to do on success
           } getOrElse {
               InternalServerError("Something has gone terribly wrong...")
           }
       }
    )
}

您可以使用在应用程序中更有意义的内容替换占位符结果。

答案 1 :(得分:1)

save(ud:User)方法返回整数值。操作应该始终返回Result,所以写

     success => {  
       val result = User.save(success)
         Ok(result.toString)
           }