我想创建自己的@NotNull版本,它可以接受一个值,例如@namedNotNull(“emailaddress”)。但是我不知道如何重写验证器中的#getPropertyPath?有没有办法做到这一点,或者我被“arg1”或“arg2”等卡住了。
编辑
根据我收到的答案,我能够提出以下实现,它允许我从@queryparam或@pathparam注释中获取值,并将它们用作Bean验证注释(如@Notnull)的属性路径。
public class ValidationConfigurationContextResolver implements ContextResolver<ValidationConfig> {
@Override
public ValidationConfig getContext( final Class<?> type ) {
final ValidationConfig config = new ValidationConfig();
config.parameterNameProvider( new RestAnnotationParameterNameProvider() );
return config;
}
static class RestAnnotationParameterNameProvider extends DefaultParameterNameProvider {
@Override
public List<String> getParameterNames( Method method ) {
Annotation[][] annotationsByParam = method.getParameterAnnotations();
List<String> names = new ArrayList<>( annotationsByParam.length );
for ( Annotation[] annotations : annotationsByParam ) {
String name = getParamName( annotations );
if ( name == null )
name = "arg" + ( names.size() + 1 );
names.add( name );
}
return names;
}
private static String getParamName( Annotation[] annotations ) {
for ( Annotation annotation : annotations ) {
if ( annotation.annotationType() == QueryParam.class ) {
return QueryParam.class.cast( annotation ).value();
}
else if ( annotation.annotationType() == PathParam.class ) {
return PathParam.class.cast( annotation ).value();
}
}
return null;
}
}
}
然后,在RestConfig中,您需要添加以下行:
register( ValidationConfigurationContextResolver.class );
就是这样。现在,您的ConstraintValidationExceptions将包含对它们进行注释的QueryParam或PathParam的名称。例如:
public void getUser(
@NotNull @QueryParam( "emailAddress" ) String emailAddress,
@NotNull @QueryParam( "password" ) String password )
{ ... }
如果您熟悉Bean验证框架,您就会知道无法获得方法参数的名称
那不太正确。Bean验证指定了ParameterNameProvider的概念,它允许您提供自己的实现。Hibernate验证器与ParaNamer集成以提供参数名称。有关更多信息,请参见验证器联机文档。一旦验证器支持Java8,它也将支持Java8参数命名工具。
伊莫,你应该让帕拉纳默试试看。
问题内容: 如果您熟悉Bean验证框架,那么您将无法获得方法参数的名称。因此,如果对方法的第一个参数执行@NotNull约束,并且验证失败,则getPropertyPath将类似于“ arg1”。 我想创建自己的@NotNull版本,该版本可以采用例如@NamedNotNull(“ emailAddress”)的值。但是我不知道如何在验证器中覆盖#getPropertyPath?有什么办法做到这一
我可以使用PHP以编程方式更改文件的路径吗? 例如,更改
我正在处理一个仅使用“autoCommit=true”创建连接的连接池。 然而,对于我的特定用例,我需要“autoCommit=false”,以便可以在JDBC语句上设置“fetch size”属性。 我的初始测试表明,我可以在JDBC连接实例上设置AutoCommit属性,然后在将连接返回到池之前再次重置它。 有人知道这是一个正确的用例吗? 我正在使用Postgres,但稍后可能会迁移到Orac
本文向大家介绍ubuntu mysql更改tmp路径的方法,包括了ubuntu mysql更改tmp路径的方法的使用技巧和注意事项,需要的朋友参考一下 ubuntu系统是一个linux操作系统;下面呐喊教程小编给大家介绍ubuntu mysql更改tmp路径的方法。 因为mysql经常要把文件定入tmp目录,而tmp的目录为/tmp,为了提高性能,所以考虑更改tmpdir目录为/run/shm,即
我有一个字符串字段,它可能在前导和尾随处包含空白。我想修剪这些空白并使用返回修剪后的文本。如果文本为空,我想返回null。 当查看此链接上显示的实现示例时,我不确定如何创建一个获取字符串并返回字符串的方法,而不是创建方法。那么,如何根据给定的场景实现这种方法呢?
代码B是一个定制的回收视图apater,带有单选按钮。 mCustomAdapter 在 Code A 中的 fun methodA() 和 fun methodB() 中都发生了变化,因此 的引用也发生了变化,这意味着 val 属性 mySelectedIndex 从不同的地址获取值。 在我看来,val属性不能更改,为什么应用程序不会导致错误? 代码A 代码B 被改进的 我觉得代码DD和代码EE
是否可以(仅仅)使用Byte-Buddy更改某些方法的可见性?我有一个带有私有静态方法的用户类,我需要将一些调用委托给这些方法,但由于它们是私有的,所以当前失败了。因此,我想知道是否可以通过添加公共修饰符来转换上述方法来重新定义user类。 对于记录,在目标Java方法上调用setAccessible(true)方法作为not effect,因为Byte Buddy仍然失败,出现以下异常: 我发现
Swagger提出了一个类似的问题:重用枚举定义作为查询参数。我的问题是我是否可以使用枚举(可重用或不可重用)。每当我尝试这样做的时候,我都会得到错误,但是使用字符串不会给出任何错误 我的问题是上面的例子是否有效,或者我应该尝试什么可能的改变。我使用的是OpenAPI 3.0.0。 错误: 我对XX.client知之甚少.cpp .它是一个自动生成的文件,是在编译yaml文件后构建的。