0

这是我的功能:

private boolean CheckPassword(String type, String login, String passwordHash) {
    EntityManagerFactory entityManagerFactory 
            = Persistence.createEntityManagerFactory("kwestionariuszFor" + type);
    EntityManager entityManager 
            = entityManagerFactory.createEntityManager();
    type = type.substring(0, 1).toUpperCase() + type.substring(1, type.length());
    List<Object> entities 
            = entityManager.createNamedQuery(type + ".findByLogin").setParameter("login", login).getResultList();
    if (passwordHash.equals(entities.get(0).Password)) {
        return true;
    }
    else {
        return false;
    }
}

Java 不“知道”任何表中都有 IS Password 列。我在想告诉它的方式可能是这样的:

List<type.toClass()>

或者什么...有什么办法可以实现我想要的吗?我不想创建如果,如果,如果之后... -_-'

4

1 回答 1

2

您必须为代表数据库表的所有类创建一个通用类型。

像这样:

public abstract class PasswordObject {
    private String password;

    public PasswordObject(String password) {
        this.password = password;
    }

    public String getPassword() {
        return password;
    }
}

我不知道该方法createNamedQuery是否能够返回 a List<PassowrdObject>,但如果不能,您可以像这样转换它(只要这样做是安全的,您只能通过使用它的方式来判断):

PasswordObject po = (PasswordObject) entities.get(0);
String password = po.getPassword();
于 2012-05-31T13:06:36.887 回答