Playframework2 Ebean:为什么不获取相关对象?

时间:2014-08-08 10:28:11

标签: java playframework-2.0 ebean

这是我的User

package models.user;

import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.FetchType;
import javax.persistence.Id;
import javax.persistence.ManyToOne;
import javax.persistence.Table;

import play.data.validation.Constraints.MaxLength;
import play.data.validation.Constraints.MinLength;
import play.data.validation.Constraints.Required;
import play.db.ebean.Model;

@Entity
@Table(name = "T_USER")
public class User extends Model {
  @Id
  public Long id;

  @Required
  @MaxLength(30)
  @MinLength(4)
  public String username;

  @Required
  @MaxLength(30)
  @MinLength(4)
  public String password;

  @ManyToOne(fetch = FetchType.EAGER)
  @Column(nullable = false)
  public Role role;

  public static Finder<Long, User> find = new Finder<Long, User>(Long.class, User.class);

  public User() {
  }

  public User(String username, String password, Role role) {
    this.username = username;
    this.password = password;
    this.role = role;
  }

  @Override
  public String toString() {
    return "[Tying to login : ] [" + username + " - " + password + "]";
  }
}

在我的控制器中,我想获得一个用户的角色实例,所以这就是我所做的:

public static Result modules(Long id) {
    User user = User.find.byId(id);
    if ("Super User".equalsIgnoreCase(user.role.name)) {
      return ok();
    } else {
      return forbidden();
    }
  }

问题是,user.role.name为空,但此处user.role.id是正确的,为什么EBean无法帮助我为用户提取role

1 个答案:

答案 0 :(得分:1)

我在不同场合遇到过这个问题。您可以执行以下操作:

首先,尝试用私有字段替换你的公共字段,并添加适当的getter和setter(无论如何,这是一个很好的模式)。

其次,您可以编写一个小助手来查找/获取所需信息。所以,让我们说你需要通过Id获取用户并执行此字符串检查。然后在User课程中,您可以编写如下方法:

public static User findById(Long id) {
    return Ebean.find(User.class)
        .fetch("role")
        .where() 
        .eq("id", id)
        .findUnique();
}

之后,只需使用方法:

public static Result modules(Long id) {
    User user = User.findById(id);
    if ("Super User".equalsIgnoreCase(user.getRole().getName())) {
      return ok();
    } else {
      return forbidden();
    }
  }