找不到类型为Double的QueryString绑定器.尝试为此类型实现隐式QueryStringBindable

5 java playframework-2.0

所以我正在使用Play 2.0,我试图将双视图从我的视图传递回控制器应用程序,我收到此错误:找不到类型为Double的QueryString绑定器.尝试为此类型实现隐式QueryStringBindable.我找到了这个帖子,看到java绑定器只能在play 2.0中使用自递归类型,但它们将在play 2.1中得到支持.不幸的是,我无法将我的项目迁移到2.1,所以我试着按照链接问题的答案.我在我的项目中创建了一个util包,里面是DoubleW类:

package util;

import java.util.Map;

import play.libs.F;
import play.libs.F.Option;
import play.mvc.QueryStringBindable;

public class DoubleW implements QueryStringBindable<DoubleW> {

    public Double value = null;

    @Override
    public Option<DoubleW> bind(String key, Map<String, String[]> data) {
        String[] vs = data.get(key);
        if (vs != null && vs.length > 0) {
            String v = vs[0];
            value = Double.parseDouble(v);
            return F.Some(this);
        }
        return F.None();
    }

    @Override
    public String unbind(String key) {
        return key + "=" + value;
    }

    @Override
    public String javascriptUnbind() {
         return value.toString();
    }

}
Run Code Online (Sandbox Code Playgroud)

我在控制器/应用程序和我需要使用双精度的模型类之一中导入了它.我在相关的应用程序和模型方法中用新的DoubleW替换了double数据类型.最后我修改了我的路由表,所以它会期望新的参数:

GET/findMatch controllers.Application.matcher(sLat:util.DoubleW,sLon:util.DoubleW,eLat:util.DoubleW,eLon:util.DoubleW)

在应用程序匹配器方法使用的模型方法中,我需要执行算术运算.但是,当我运行我的项目时,我收到此错误:错误:二元运算符'<='的错误操作数类型.似乎这个处理双精度(DoubleW)的新类型被认为是一个字符串,我不能对它进行算术运算而且我不能为其分配标准的java double值.我不确定我是否错过了上一篇文章中的一个步骤,但我很遗憾该怎么做.

Mar*_*ier 6

在Play 2.0中,我发现最简单的解决方案是使用Scala - 即使在Java项目中(我在我的Play Basics博客文章中解释过这一点).

如果您不了解Scala,只需将以下内容粘贴到一个名为的文件中即可Binders.scala添加routesImport += "util.Binders._"到您的文件中Build.scala.

package util

object Binders {

  implicit object DoubleQueryBindable extends QueryStringBindable[Double] {
    def bind(key: String, params: Map[String, Seq[String]]) = params.get(key).flatMap(_.headOption).map { value =>
      try {
        Right(value.toDouble)
      } catch {
        case e: Exception =>  Left("Cannot parse parameter " + key + " as Double")
      }
    }
    def unbind(key: String, value: Double) = key + "=" + value.toString
  }

  implicit object DoublePathBindable extends PathBindable[Double] {
    def bind(key: String, value: String) = try {
      Right(value.toDouble)
    } catch {
      case e: Exception => Left("Cannot parse parameter '" + key + "' as Double")
    }

    def unbind(key: String, value: Double): String = value.toString
  }
}
Run Code Online (Sandbox Code Playgroud)