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

时间:2013-03-29 12:24:02

标签: java playframework-2.0

所以我正在使用Play 2.0,我试图将双视图从我的视图传递回控制器应用程序,我收到此错误:找不到类型为Double的QueryString活页夹。尝试为此类型实现隐式QueryStringBindable 。我找到了this线程,看到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();
    }

}

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

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

在Application matcher方法使用的模型方法中,我需要执行算术运算。但是,当我运行我的项目时,我收到此错误:错误:二元运算符'&lt; ='的错误操作数类型。似乎这个处理双精度(DoubleW)的新类型被认为是一个字符串,我无法对其执行算术,我无法为其分配标准java double的值。我不确定我是否错过了之前的post中的一步,但我对于该做什么感到很遗憾。

1 个答案:

答案 0 :(得分:6)

在Play 2.0中,我发现最简单的解决方案是使用Scala - 即使是在Java项目中(我在my Play Basics blog posts中解释过这个。

如果您不了解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
  }
}