@Controller,@Service,@Repository,@Component详解。-阿里云开发者社区

开发者社区> 开发与运维> 正文
登录阅读全文

@Controller,@Service,@Repository,@Component详解。

简介: @Controller 用来表示一个web控制层bean,如SpringMvc中的控制器。 @Service 用来表示一个业务层bean。 @Repository 用来表示一个持久层bean,即数据访问层DAO组件。

@Controller

用来表示一个web控制层bean,如SpringMvc中的控制器。

@Service

用来表示一个业务层bean。

@Repository

用来表示一个持久层bean,即数据访问层DAO组件。

@Component

用来表示一个平常的普通组件,当一个类不合适用以上的注解定义时用这个组件修饰。

需要注意的是@Controller,@Service,@Repository都有带@Component父注解,说明它们除了基本组件的属性外还有其他的的场景应用,即如果不用SpringMVC其实它们就是一个普通的组件,但普通组件建议最好还是用@Component修饰。

为了让Spring自动扫描注册这些组件,需要在配置文件中加上扫描的配置,如扫描com.test包下的注解。

些扫描配置默认use-default-filters="true",默认扫描@Component注解及子注解,可以配置过滤只扫描哪些注解不扫描哪些注解。

要过滤扫描注解,需要相应的带上下面的子标签,可以有多个。

如只扫描com.test包下的@Controller和@Service注解的组件。

关于type的定义

Filter TypeExamples ExpressionDescription

annotationorg.example.SomeAnnotation符合SomeAnnoation的target class

assignableorg.example.SomeClass指定class或interface的全名

aspectjorg.example..*Service+AspectJ语法

regexorg\.example\.Default.*Regelar Expression

customorg.example.MyTypeFilter自定义Type,实现接口org.springframework.core.type.TypeFilter

另外,配置可以有多个。

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

分享: