(1)在spring4之后,要使用注解开发,必须要保证aop的包导入了
使用注解需要导入context约束,增加注解的支持!
精简版:
- "1.0" encoding="UTF-8"?>
- <beans xmlns="http://www.springframework.org/schema/beans"
- xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
- xmlns:context="http://www.springframework.org/schema/context"
- xsi:schemaLocation="http://www.springframework.org/schema/beans
- https://www.springframework.org/schema/beans/spring-beans.xsd
- http://www.springframework.org/schema/context
- https://www.springframework.org/schema/context/spring-context.xsd">
-
- <context:annotation-config/>
-
-
-
- beans>
扩展版:
- "1.0" encoding="UTF-8"?>
- <beans xmlns="http://www.springframework.org/schema/beans"
- xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
- xmlns:context="http://www.springframework.org/schema/context"
- xsi:schemaLocation="http://www.springframework.org/schema/beans
- https://www.springframework.org/schema/beans/spring-beans.xsd
- http://www.springframework.org/schema/context
- https://www.springframework.org/schema/context/spring-context.xsd">
-
- <context:annotation-config/>
-
-
- <context:component-scan base-package="com.gt.pojo"/>
-
-
- beans>
(2)bean
绿色的叶子表示放入组件当中!
- package com.gt.pojo;
-
- import org.springframework.stereotype.Component;
-
- //@Component 等价于
- //@Component 组件
-
- @Component
- public class User {
-
- public String name = "山姆";
- }
- import com.gt.pojo.User;
- import org.springframework.context.ApplicationContext;
- import org.springframework.context.support.ClassPathXmlApplicationContext;
-
- public class MyTest {
- public static void main(String[] args) {
- ApplicationContext context = new ClassPathXmlApplicationContext("applicationContext.xml");
- //getBean括号里面的东西就是默认类的小写
- User user = context.getBean("user",User.class);
- System.out.println(user.name);
- }
- }
(3)属性如何注入
- package com.gt.pojo;
-
- import org.springframework.beans.factory.annotation.Value;
- import org.springframework.stereotype.Component;
-
- //@Component 等价于
- //@Component 组件
-
- @Component
- public class User {
-
- //@Value("shanmu2") 相当于在beans.xml中
-
- public String name;
-
- @Value("shanmu2")
- public void setName(String name) {
- this.name = name;
- }
- }
1、衍生的注解
@Component有几个衍生注解,我们在web开发中,会按照mvc三层架构分层
dao【@Repository】
service【@Service】
controller【@Controller】
这四个注解功能都是一样的,都是代表某个类注册到spring,装配bean
2、自动装配
3、作用域
- /**
- * @Component 等价于
- *
- */
- @Component
- // @Scope("prototype") 这个等价于作用域
- @Scope("prototype")
- public class User {
- /**
- * 相当于
- *
- *
- *
- */
- // @Value("山姆02")
- public String name;
-
-
- @Value("shanmu02")
- public void setName(String name) {
- this.name = name;
- }
- }
xml更加万能,适用于任何场合,维护简单方便
注解不是自己的类使用不了,维护相对复杂
xml用来管理bean
注解只负责完成属性的注入
我们在使用的过程中,需要注意一个问题:必须让注解生效,就需要开启注解的支持
- <context:annotation-config/>
-
-
- <context:component-scan base-package="com.gt"/>