我正在开发一个包含大量输入表单的Spring应用程序。我想在UI表单,验证和JPA注释中重用字段长度。有没有一种优雅的方法来解决这个问题。我现在的解决方案是,使用常量来声明长度:

public class Person
{
   public static final int FIRSTNAME_LENGTH = 25;

   @Column(length=FIRSTNAME_LENGTH)
   private String firstName;

   ...
}

然后在Validator和Jsp中重用常量

...

<form:input path="firstName" 
    maxlength="<%= Integer.toString(Person.FIRSTNAME_LENGTH) %>"/>

...

非常详细。

这个问题还有更优雅的解决方案吗?

有帮助吗?

解决方案

很有可能访问存储在注释中的信息。实际上,这是他们的主要目的:在类/方法/字段上存储元信息。 以下是如何访问存储在@Column注释中的长度的示例:

import javax.persistence.Column;
import javax.persistence.Entity;

@Entity
public class Person {

   @Column(length=30)
   private String firstName;

   public static void main(String[] args) throws SecurityException, NoSuchFieldException {
      Object person = new Person();
      //find out length    
      System.out.println(person.getClass().getDeclaredField("firstName").getAnnotation(Column.class).length());
   }
}

您应该能够创建一些自定义标记或bean来一般性地提取此信息。

创建自己的注释并不困难。您可以考虑创建一个指定要在表单中包含哪些字段,如何呈现它们,描述等等。您可以创建一个通用表单。然后你可能不喜欢混合使用域名和演示文稿。

其他提示

当我使用Hibernate时,我问了一个类似的问题,

  

从Hibernate映射中获取列长度?

不知道如何在JPA下提取这些信息,但如果您使用Hibernate作为底层,您可以尝试直接访问Hibernate并实现上述解决方案。

然而,Hibernate解决方案与您在答案中概述的解决方案一样优雅,其缺点是它将您的JPA实现与Hibernate联系起来。

EJB提供的解决方案读取列长度的注释值。 James McMahon指出这暴露了Hibernate的实现。使用getter方法可以相当简单地解决这个问题。假设Person的接口具有声明的方法getFirstNameLength:

import javax.persistence.Column;
import javax.persistence.Entity;

@Entity
public class PersonImplementation extends Person {

   @Column(length=30)
   private String firstName;

   public int getFirstNameLength() {
       return this.getClass().getDeclaredField("firstName").getAnnotation(Column.class).length();
   }
}
许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top