1
回答
让 ActiveJDBC 的数据验证支持国际化 (I18N)
注册华为云得mate10,2.9折抢先购!>>>   

ActiveJDBC 在进行数据验证时的做法如下:

public class Temperature extends Model{
   static{
      validateRange("temp", 10, 2000).message("Temperature is outside the limit");
   }
}

但这种指定了特定的提示信息,不利于多国语言的支持,因此你可以这样:

public class Temperature extends Model{
   static{
      validateRange("temp", 10, 2000).message("temperature.outside.limits");
   }
}

然后我们需要一个资源文件:activejdbc_messages.properties

#activejdbc_messages.properties:
temperature.outside.limits = Temperature needs to be between {0} and {1} for user: {2}

你也可以这样直接来读取 properties 中设定的字符串

String user = "Tom";
Temperature temp = new Temperature();
if(!temp.save()){
   String message = temp.errors().get("temp", user);
   System.out.println(message);// prints: Temperature is outside acceptable limits, while it needs to be between 10 and 2000 for user: Tom
}

或者是指定 Locale 进行读取

Temperature temp = new Temperature();
temp.set("temp", 5000);
if(!temp.save()){
   String message = temp.errors(new Locale("de", "DE")).get(temp); //<<<=== provide locale
   System.out.println(message);// prints: Die Temperatur liegt außerhalb akzeptabler Grenzen, während es sein muss zwischen 10 und 2000
}

更多关于 ActiveJDBC 的数据验证请看官方文档

举报
红薯
发帖于7年前 1回/371阅
顶部