这篇文章主要介绍了怎么使用Spring组合自定义的注释mscharhag操作,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。
假设我们有一组经常一起使用的Spring注释。一个常见的示例是@Service和@Transactional的组合:
@Service @Transactional(rollbackFor = Exception.<b>class</b>, timeout = 5) <b>public</b> <b>class</b> UserService { ... }
如果希望在所有服务类上用这两个注释,现在不必一遍又一遍地重复注释了,我们可以创建一个新注释包含这两个注释。创建我们自己的注释非常简单,如下所示:
@Service @Transactional(rollbackFor = Exception.<b>class</b>, timeout = 5) @Retention(RetentionPolicy.RUNTIME) <b>public</b> @<b>interface</b> MyService {}
注释是使用@interface关键字定义的(而不是类或接口)。标准Java注释@Retention用于指示注释应在运行时可处理。我们还将两个Spring注释都添加到了注释中。
现在,我们可以使用自己的@MyService批注来批注我们的服务:
@MyService <b>public</b> <b>class</b> UserService { ... }
Spring现在检测到@MyService被@Service和@Transactional注释,并提供与前面的示例UserService相同的行为。
请注意,这是Spring注释处理方式的功能,而不是一般的Java功能。
自定义注释可以在各种情况下使用,以提高代码的可读性。这是另外两个可能派上用场的例子。
也许我们在代码的各个位置都需要一个属性值。通常使用Spring的@Value注释注入属性:
<font><i>// injects configuration properties my.api.key</i></font><font> @Value(</font><font>"${my.api.key}"</font><font>) <b>private</b> String apiKey; </font>
在这种情况下,我们可以将属性表达式从代码中移到单独的注释中:
@Value(<font>"${my.api.key}"</font><font>) @Retention(RetentionPolicy.RUNTIME) <b>public</b> @<b>interface</b> ApiKey {} </font>
现在,在我们的代码中,我们可以使用@ApiKey而不是在各处重复属性表达式:
@ApiKey <b>private</b> String apiKey;
另一个例子是集成测试。在测试中,通常使用各种Spring批注来定义测试设置。可以使用自定义注释将这些注释分组在一起。例如,我们可以创建一个@MockMvcTest注释,该注释定义模拟mvc测试的Spring设置:
@SpringBootTest @AutoConfigureMockMvc(secure = false) @TestPropertySource(locations = <font>"classpath:test.properties"</font><font>) @ExtendWith(SpringExtension.<b>class</b>) @Retention(RetentionPolicy.RUNTIME) <b>public</b> @<b>interface</b> MockMvcTest {} </font>
现在,我们的测试定义看起来更加清晰。我们只需要添加@MockMvcTest即可获得完整的测试设置:
@MockMvcTest <b>public</b> <b>class</b> MyTest { ... }
感谢你能够认真阅读完这篇文章,希望小编分享的“怎么使用Spring组合自定义的注释mscharhag操作”这篇文章对大家有帮助,同时也希望大家多多支持亿速云,关注亿速云行业资讯频道,更多相关知识等着你来学习!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。