Spring的Java配置方式

Spring的Java配置方式

1 @Configuration 和 @Bean

Java配置是Spring4.x推荐的配置方式,可以完全替代xml配置。Spring的Java配置方式是通过 @Configuration 和 @Bean 这两个注解实现的:

1、@Configuration 作用于类上,相当于一个xml配置文件;

2、@Bean 作用于方法上,相当于xml配置中的<bean>;/<bean>

2 示例

该示例演示了通过Java配置的方式进行配置Spring,并且实现了Spring IOC功能。  

2.1 创建工程以及导入依赖(Maven)

<code><project>    <modelversion>4.0.0/<modelversion>    <groupid>cn.qiaoliqiang/<groupid>    <artifactid>spring-boot/<artifactid>    <version>0.0.1-SNAPSHOT/<version>    <packaging>war/<packaging>
<dependencies> <dependency> <groupid>org.springframework/<groupid> <artifactid>spring-webmvc/<artifactid> <version>4.3.7.RELEASE/<version> /<dependency> <dependency> <groupid>com.jolbox/<groupid> <artifactid>bonecp-spring/<artifactid> <version>0.8.0.RELEASE/<version> /<dependency> /<dependencies> <build> <finalname>${project.artifactId}/<finalname> <plugins> <plugin> <groupid>org.apache.maven.plugins/<groupid> <artifactid>maven-resources-plugin/<artifactid> <configuration> <encoding>UTF-8/<encoding> /<configuration> /<plugin> <plugin> <groupid>org.apache.maven.plugins/<groupid> <artifactid>maven-compiler-plugin/<artifactid> <configuration> <source>1.7/<source> <target>1.7/<target> <encoding>UTF-8/<encoding> /<configuration> /<plugin> /<plugins> <pluginmanagement> <plugins> <plugin> <groupid>org.apache.tomcat.maven/<groupid> <artifactid>tomcat7-maven-plugin/<artifactid> <version>2.2/<version> /<plugin> /<plugins> /<pluginmanagement> /<build>/<project>/<code>

2.2 编写User对象

<code>package cn.qlq;
public class User { private String username; private String password; private int age;
public String getUsername() { return username; }
public void setUsername(String username) { this.username = username; }
public String getPassword() { return password; }
public void setPassword(String password) { this.password = password; }

public int getAge() { return age; }
public void setAge(int age) { this.age = age; }
}/<code>

2.3 编写UserDAO 用于模拟与数据库的交互(注意此DAO没有打注解)

<code>packagecn.qlq;import java.util.ArrayList;import java.util.List;
/** * 模拟UserDao查询数据库 * * @author liqiang * */public class UserDao { /** * 模拟查到10个 用户 * * @return */ public List<user> queryUserList() { List<user> result = new ArrayList<user>(); // 模拟数据库的查询 for (int i = 0; i < 10; i++) { User user = new User(); user.setUsername("username_" + i); user.setPassword("password_" + i); user.setAge(i + 1); result.add(user); } return result; }
}/<user>/<user>/<user>/<code>

2.4 编写UserService 用于实现User数据操作业务逻辑(声明service注解,且自动注入dao对象)

<code>packagecn.qlq;import java.util.List;
import org.springframework.beans.factory.annotation.Autowired;import org.springframework.stereotype.Service;
//声明是service层对象@Servicepublic class UserService { @Autowired // 自动注入Spring容器中的dao层对象(byType注入) private UserDao UserDao;
public List<user> queryUserList() { // 调用userDAO中的方法进行查询 return this.UserDao.queryUserList(); }
}/<user>/<code>

2.5 编写SpringConfig 用于实例化Spring容器

打上@Configuration注解,同时打上@ComponentScan配置扫描的包。

@Bean用于向容器中放入对象,如果在UserDao类前面打上@Repository注解就不用@Bean方式

<code>packagecn.qlq;import org.springframework.context.annotation.Bean;import org.springframework.context.annotation.ComponentScan;import org.springframework.context.annotation.Configuration;
@Configuration // 通过该注解来表明该类是一个Spring的配置,相当于一个xml文件@ComponentScan(basePackages = "cn.qlq") // 配置扫描包public class SpringConfig {
@Bean // 通过该注解来表明是一个Bean对象,相当于xml中的<bean> public UserDao getUserDAO() { return new UserDao(); // 直接new对象做演示 }
}/<bean>/<code>

注意:方法名是作为返回对象的名字的,因此一般不带get,也就是上述放入spring容器的bean的name为getUserDAO  

2.6 编写测试方法 用于启动Spring容器

<code>packagecn.qlq;importjava.util.List;import org.springframework.context.annotation.AnnotationConfigApplicationContext;
/** * 测试类 * * @author liqiang * */public class Test {
public static void main(String[] args) { // 通过Java配置来实例化Spring容器 AnnotationConfigApplicationContext context = new AnnotationConfigApplicationContext(SpringConfig.class);
// 在Spring容器中获取Bean对象 UserService userService = context.getBean(UserService.class);
// 调用对象中的方法 List<user> list = userService.queryUserList(); for (User user : list) { System.out.println(user.getUsername() + ", " + user.getPassword() + ", " + user.getPassword()); }
// 销毁该容器 context.destroy(); }
}/<user>/<code>

结果:

<code>username_0, password_0, password_0username_1, password_1, password_1username_2, password_2, password_2username_3, password_3, password_3username_4, password_4, password_4username_5, password_5, password_5username_6, password_6, password_6username_7, password_7, password_7username_8, password_8, password_8username_9, password_9, password_9/<code>

3 总结

从以上的示例中可以看出,使用Java代码就完美的替代xml配置文件,并且结构更加的清晰。

使用方法:

Spring对Java配置的支持是由@Configuration注解和@Bean注解来实现的。由@Bean注解的 方法将会实例化、配置和初始化一个 新对象,这个对象将由Spring的IoC容器来管理。@Bean声明所起到的作用与<bean> 元素类似。被 @Configuration所注解的类则表示这个类的主要目的是作为bean定义的资源。被@Configuration声明的类可以通过在同一个类的 内部调用@bean方法来设置嵌入bean的依赖关系。

最简单的@Configuration 声明类请参考下面的代码:(放入spring的name为方法名字,因此一般不加get)

<code>@Configuration    public class AppConfig{        @Bean        public MyService myService() {            return new MyServiceImpl();        }    }/<code>

对于上面的@Beans配置文件相同的XML配置文件如下:

<code><beans>        <bean>    /<beans> /<code>

上述配置方式的实例化方式如下:

利用AnnotationConfigApplicationContext 类进行实例化

<code>public static void main(String[] args) {        ApplicationContext ctx = new AnnotationConfigApplicationContext(AppConfig.class);        MyService myService = ctx.getBean(MyService.class);        myService.doStuff();    }/<code>

要使用组件组建扫描,仅需用@Configuration进行注解即可:

<code>@Configuration    @ComponentScan(basePackages = "com.somnus")    public class AppConfig  {        ...    }/<code>

在上面的例子中,com.acme包首先会被扫到,然后再容器内查找被@Component 声明的类,找到后将这些类按照Sring bean定义进行注册。

补充:关于@Bean的参数注入问题:

<code>  @Bean    public User user2(User user) {         System.out.println("user is -> "+ user);        User user2 = new User();        user2.setUsername("user2");        return user2;    }/<code>

如上,有参数user,若spring容器中只有一个User类型的bean,则不论参数取名为何都是按类型取bean user为参数,若有多个则参数取名必须为多个bean中的一个,否则报错。

例如:下面会报错:

<code>@Bean    public User user1() {        User user = new User();        user.setUsername("user1");        return user;    }
@Bean public User user2(User user) { System.out.println("user is -> "+ user); User user2 = new User(); user2.setUsername("user2"); return user2; } @Bean public User user3(User user) { System.out.println("user is -> "+ user); User user2 = new User(); user2.setUsername("user2"); return user2; }/<code>
<code>Description:
Parameter 0 of method user2 in cn.qlq.config.RedisCacheConfig required a single bean, but 2 were found:- user1: defined by method 'user1' in class path resource [cn/qlq/config/RedisCacheConfig.class]-user3:definedbymethod'user3'inclasspathresource[cn/qlq/config/RedisCacheConfig.class]Action:Consider marking one of the beans as @Primary, updating the consumer to accept multiple beans, or using @Qualifier to identify the bean that should be consumed/<code>

修改为以下即可成功:

<code> @Bean    public User user1() {        User user = new User();        user.setUsername("user1");        return user;    }
@Bean public User user2(User user1) { System.out.println("user1 is -> "+ user1); User user2 = new User(); user2.setUsername("user2"); return user2; } @Bean public User user3(User user2) { System.out.println("user2 is -> "+ user2); User user23 = new User(); user23.setUsername("user3"); return user23; }/<code>

启动查看 注入的信息:(多个类型按name进行注入)

<code>user1 is -> User [id=null, username=user1, password=null, userfullname=null, createtime=null, isdeleted=null, sex=null, address=null]user2 is -> User [id=null, username=user2, password=null, userfullname=null, createtime=null, isdeleted=null, sex=null, address=null]/<code>

关于Spring的Java配置方式,你学会了多少?欢迎在留言区评论


分享到:


相關文章: