Spring学习之路——注解开发
一、引入相关包和约束
在spring4之后,想要使用注解形式,必须得要引入aop的包.
这里我们可以去maven仓库中找到相关的包。
在配置文件当中,还得要引入一个context约束。
<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
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd">
二、Bean的实现
我们之前都是使用 bean 的标签进行bean注入,但是实际开发中,使用注解开发的情况多一些。
首先我们先要在Bean中配置扫描哪些包下的注解。
<context:component-scan base-package="com.zanglili"/>
这里我们来扫描zanglili包下的注解
之后在指定包下添加相关的类
package com.zanglili;
import org.springframework.stereotype.Component;
@Component("user")
public class User {
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
//@Value("DirtyLily")
public String name ="zanglili";
}
写一个测试类
import com.zanglili.User;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
public class MainTest {
public static void main(String[] args) {
ApplicationContext context = new ClassPathXmlApplicationContext("beans.xml");
User user1 = (User) context.getBean("user");
System.out.println(user1.name);
}
}
我们运行一下
完全没有什么问题
我们可以使用@Value标签在属性上面进行属性值的注入。
1.我们可以在属性的上面进行注入。
@Value("DirtyLily")
public String name;
就像这样,我们输出结果看看什么情况。
发现成功对属性进行赋值!
如果属性提供了Setter方法,也可以在Setter方法上进行赋值。
@Value("DirtyLily")
public void setName(String name) {
this.name = name;
}
结果还是一样的。
三、衍生注解
@Component 还有三个衍生注解,这些衍生注解是为了在以后大型项目中进行更好的分层而使用的,目前来说功能没有任何区别。
- @Controller:web层
- @Service:service层
- @Repository:dao层
四、作用域
在类上面使用@Scope注解可以规定作用域。
主要有这么几个参数
- singleton:默认的,Spring会采用单例模式创建这个对象。关闭工厂 ,所有的对象都会销毁。
- prototype:多例模式。关闭工厂 ,所有的对象不会销毁。内部的垃圾回收机制会回收
还有request session等作用域,具体大家可以查阅官方文档,在这里我就不赘述了。
五、基于Java类进行配置Bean
Spring可以通过一个Java类来提供bean的定义信息,现在这种定义方式也非常的常用。实现也是很简单,我们来康康。
首先我们先创建一个狗类,里面有一个name字符串
package com.dao;
import org.springframework.stereotype.Component;
@Component
public class dog {
public int age;
public String name = "dog";
}
我们需要在上面写一个@Component注解,将这个类作为Spring组件放到Spring容器中。
之后我们要写一个配置类,这个类相当于xml中的beans,使用@Configuration标记其为配置类,在类中用@Bean注解方法,等价于XML配置的< bean>,方法名等于beanId。比如说
package com.config;
import com.dao.dog;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
@Configuration
public class Myconfig {
@Bean
public dog dog(){
dog lili = new dog();
lili.age = 5;
return lili;
}
}
我们这里通过Myconfig返回了一个5岁的狗,
上面这段代码就相当于<bean id = “dog” class = "dog> </ bean>
我们测试下
import com.config.Myconfig;
import com.dao.dog;
import org.junit.Test;
import org.springframework.context.ApplicationContext;
import org.springframework.context.annotation.AnnotationConfigApplicationContext;
public class Mytest {
@Test
public void test2(){
ApplicationContext applicationContext =
new AnnotationConfigApplicationContext(Myconfig.class);
dog dog = (dog) applicationContext.getBean("dog");
System.out.println(dog.name);
System.out.println(dog.age);
}
}
这里要注意的是我们的ApplicationContext 要指向一个AnnotationConfigApplicationContext而不是之前的ClassPathXmlApplicationContext,这其中里面的参数是我们配置的配置类。
最后结果和我们想的一样!
六、总结
这里依然是借用一下@狂人说老师的总结。
老师的博客是这么写的
XML与注解比较
- XML可以适用任何场景 ,结构清晰,维护方便
- 注解不是自己提供的类使用不了,开发简单方便
xml与注解整合开发 :推荐最佳实践
-
xml管理Bean
-
注解完成属性注入
-
使用过程中, 可以不用扫描,扫描是为了类上的注解
关于Java类的配置方式和注解开发,我们在之后的SpringBoot 和 SpringCloud中还会大量看到,到目前我们需要知道这些注解的作用即可!
具体大家可以参照老师的博客。
https://blog.kuangstudy.com/index.php/archives/524/