• Spring的Java配置方式


    Java配置是Spring4.x推荐的配置方式,可以完全替代xml配置。

    1     @Configuration 和 @Bean

    Spring的Java配置方式是通过 @Configuration 和 @Bean 这两个注解实现的:

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

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

    2 示例

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

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

    <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
        xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
        <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>
                <!-- java编译插件 -->
                <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>
                    <!-- 配置Tomcat插件 -->
                    <plugin>
                        <groupId>org.apache.tomcat.maven</groupId>
                        <artifactId>tomcat7-maven-plugin</artifactId>
                        <version>2.2</version>
                    </plugin>
                </plugins>
            </pluginManagement>
        </build>
    </project>

      2.2   编写User对象

    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;
        }
    
    }

     

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

    package cn.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;
        }
    
    }

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

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

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

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

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

    package cn.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对象做演示
        }
    
    }

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

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

    package cn.qlq;
    
    import java.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();
        }
    
    }

    结果:

    username_0, password_0, password_0
    username_1, password_1, password_1
    username_2, password_2, password_2
    username_3, password_3, password_3
    username_4, password_4, password_4
    username_5, password_5, password_5
    username_6, password_6, password_6
    username_7, password_7, password_7
    username_8, password_8, password_8
    username_9, password_9, password_9

    总结:

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

     使用方法:

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

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

    复制代码
    @Configuration    
    public class AppConfig{    
        @Bean    
        public MyService myService() {    
            return new MyServiceImpl();    
        }    
    }  
    复制代码

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

    <beans>    
        <bean id="myService" class="com.somnus.services.MyServiceImpl"/>    
    </beans> 

    上述配置方式的实例化方式如下:利用AnnotationConfigApplicationContext 类进行实例化

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

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

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

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

     

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

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

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

     

    例如:下面会报错:

        @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;
        }

    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: defined by method 'user3' in class path resource [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

    修改为以下即可成功:

        @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;
        }

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

    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]

     

     

     

  • 相关阅读:
    ASPxGridView控件的基本属性
    未整理笔记
    ASPxGridView中Command列自定义按钮点击事件概要
    Cookie的使用
    ASPxGridView行的选中和行的焦点
    改变“骨感”,让OKR变得“丰满”
    高成就者的5个共同点
    项目的风险管理
    实际执行动作对OKR目标落地的重要性
    13种公认的高绩效习惯
  • 原文地址:https://www.cnblogs.com/qlqwjy/p/7967679.html
Copyright © 2020-2023  润新知