使用play,对字段进行校验,只需要使用注解即可,连javascript都不用写
得益于play.data.validation.*这个包下的东东!
对User类的email字段和password进行验证
Java代码
- package models;
- import java.util.ArrayList;
- import java.util.List;
- import javax.persistence.Entity;
- import javax.persistence.OneToMany;
- import play.data.validation.Email;
- import play.data.validation.Required;
- import play.db.jpa.Model;
- @Entity
- public class User extends Model {
- @Required
- public String email;
- @Required(message="input your pwd now!")
- public String password;
- public String fullname;
- public boolean isAdmin;
- //@OneToMany 声明User与Post之间是1对多的关系
- //mappedBy="author" 表示将通过对方(User)的author字段来进行关联关系的维护
- @OneToMany(mappedBy="author")
- public List<Post> posts;
- public User(String email,String password, String fullname) {
- this.email = email;
- this.password = password;
- this.fullname = fullname;
- this.posts = new ArrayList<Post>(0);
- }
- /**
- * 联合email和password两个条件查询User
- * @param email
- * @param password
- * @return
- */
- public static User connect(String email, String password) {
- return find("byEmailAndPassword", email, password).first();
- }
- /**
- * 添加Post的动作放到User中,这样可以把Post设置到User的List<Post>集合中
- * 这样实现了双方都持有对方的引用了
- * @param title
- * @param content
- * @return
- */
- public User addPost(String title, String content) {
- Post post = new Post(title,content,this).save();
- this.posts.add(post);
- this.save();
- return this;
- }
- @Override
- public String toString() {
- return "User [" + fullname + "]";
- }
- }
什么都不输,保存一个User对象
会提示错误信息到页面的,play真实个大好人啊,什么活都给干了!
注意:使用CRUD在页面操作,对象的创建过程:
1.调用默认构造函数生成一个对象
2.查询数据库,把数据赋值到这个对象
3.页面呈现此对象的相关属性
如果在页面新创建一个对象,则不会查询数据库
1.调用默认构造函数生成一个对象
2.为对象赋值(如果默认构造函数中有这样做)
3.页面呈现各个字段为空的对象,如果有为字段设置默认值,可在默认构造函数中操作
4.页面输入数据,保存对象
这里想说的是:对于createTime这样的字段值,一般是后台new Date()创建的,在页面使用CRUD貌似还不能对其进行控制,因为页面会呈现这个字段出现让用户输入(是否可以通过js控制其disabled状态呢?)暂时有这样一个疑问!有人知否?或者play提供了禁止编辑的注解,是什么???