zoukankan      html  css  js  c++  java
  • 基于注解的ioc搭建

    基于注解的ioc搭建

    com文件夹的配置内容一致。

    spring中的新注解

    Configuration

    作用:指定当前类是一个配置类

    细节:当配置类作为AnnotationConfigApplicationContext对象创建的参数时,该注解可以不写。

    ComponentScan

    作用:用于通过注解指定spring在创建容器时要扫描的包

    属性:

    value:它和basePackages的作用是一样的,都是用于指定创建容器时要扫描的包。

    我们使用此注解就等同于在xml中配置了:

    <context:component-scan base-package="com.itheima"></context:component-scan>

    Bean

    作用:用于把当前方法的返回值作为bean对象存入spring的ioc容器中

    属性:

    name:用于指定bean的id。当不写时,默认值是当前方法的名称

    细节:当我们使用注解配置方法时,如果方法有参数,spring框架会去容器中查找有没有可用的bean对象。

    查找的方式和Autowired注解的作用是一样的

    Import

    作用:用于导入其他的配置类

    属性:

    value:用于指定其他配置类的字节码。

    当我们使用Import的注解之后,有Import注解的类就父配置类,而导入的都是子配置类

    PropertySource

    作用:用于指定properties文件的位置

    属性:

    value:指定文件的名称和路径。

    关键字:classpath,表示类路径下

    配置类

    该类是一个配置类,它的作用和bean.xml是一样的

    配置类代码

    package config;
    
    import org.springframework.context.annotation.ComponentScan;
    import org.springframework.context.annotation.Import;
    import org.springframework.context.annotation.PropertySource;
    
    //@Configuration
    @ComponentScan("com.itheima")
    @Import(JdbcConfig.class)
    @PropertySource("classpath:jdbcConfig.properties")
    public class SpringConfiguration {
    
    
    }
    
    
    

    和spring连接数据库相关的配置类

    package config;
    
    import com.mchange.v2.c3p0.ComboPooledDataSource;
    import org.apache.commons.dbutils.QueryRunner;
    import org.springframework.beans.factory.annotation.Qualifier;
    import org.springframework.beans.factory.annotation.Value;
    import org.springframework.context.annotation.Bean;
    import org.springframework.context.annotation.Scope;
    
    import javax.sql.DataSource;
    
    /**
     * 和spring连接数据库相关的配置类
     */
    public class JdbcConfig {
    
        @Value("${jdbc.driver}")
        private String driver;
    
        @Value("${jdbc.url}")
        private String url;
    
        @Value("${jdbc.username}")
        private String username;
    
        @Value("${jdbc.password}")
        private String password;
    
        /**
         * 用于创建一个QueryRunner对象
         * @param dataSource
         * @return
         */
        @Bean(name="runner")
        @Scope("prototype")
        public QueryRunner createQueryRunner(@Qualifier("ds2") DataSource dataSource){
            return new QueryRunner(dataSource);
        }
    
        /**
         * 创建数据源对象
         * @return
         */
        @Bean(name="ds2")
        public DataSource createDataSource(){
            try {
                ComboPooledDataSource ds = new ComboPooledDataSource();
                ds.setDriverClass(driver);
                ds.setJdbcUrl(url);
                ds.setUser(username);
                ds.setPassword(password);
                return ds;
            }catch (Exception e){
                throw new RuntimeException(e);
            }
        }
    
        @Bean(name="ds1")
        public DataSource createDataSource1(){
            try {
                ComboPooledDataSource ds = new ComboPooledDataSource();
                ds.setDriverClass(driver);
                ds.setJdbcUrl("jdbc:mysql://localhost:3306/eesy02");
                ds.setUser(username);
                ds.setPassword(password);
                return ds;
            }catch (Exception e){
                throw new RuntimeException(e);
            }
        }
    }
    

    resources

    jdbc.driver=com.mysql.jdbc.Driver
    jdbc.url=jdbc:mysql://localhost:3306/eesy
    jdbc.username=root
    jdbc.password=1234
    

    测试类-----CRUD操作

    使用Junit单元测试:测试我们的配置

    Spring整合junit的配置

    1、导入spring整合junit的jar(坐标)

    2、使用Junit提供的一个注解把原有的main方法替换了,替换成spring提供的

    @Runwith

    3、告知spring的运行器,spring和ioc创建是基于xml还是注解的,并且说明位置

    @ContextConfiguration

    locations:指定xml文件的位置,加上classpath关键字,表示在类路径下

    classes:指定注解类所在地位置

    当我们使用spring 5.x版本的时候,要求junit的jar必须是4.12及以上

    package com.itheima.test;
    
    import com.itheima.domain.Account;
    import com.itheima.service.IAccountService;
    import config.SpringConfiguration;
    import org.junit.Test;
    import org.junit.runner.RunWith;
    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.test.context.ContextConfiguration;
    import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
    
    import java.util.List;
    
    @RunWith(SpringJUnit4ClassRunner.class)
    @ContextConfiguration(classes = SpringConfiguration.class)
    public class AccountServiceTest {
    
        @Autowired
        private IAccountService as = null;
    
    
        @Test
        public void testFindAll() {
            //3.执行方法
            List<Account> accounts = as.findAllAccount();
            for(Account account : accounts){
                System.out.println(account);
            }
        }
    
        @Test
        public void testFindOne() {
            //3.执行方法
            Account account = as.findAccountById(1);
            System.out.println(account);
        }
    
        @Test
        public void testSave() {
            Account account = new Account();
            account.setName("test anno");
            account.setMoney(12345f);
            //3.执行方法
            as.saveAccount(account);
    
        }
    
        @Test
        public void testUpdate() {
            //3.执行方法
            Account account = as.findAccountById(4);
            account.setMoney(23456f);
            as.updateAccount(account);
        }
    
        @Test
        public void testDelete() {
            //3.执行方法
            as.deleteAccount(4);
        }
    }
    

  • 相关阅读:
    LocalDate/LocalDateTime与String的互相转换示例(附DateTimeFormatter详解)
    MyBatis中的JdbcType映射介绍
    mybatis的一些特殊符号标识(大于,小于,等于,不等于)
    c++多重继承
    tensorflow 一些好的blog链接和tensorflow gpu版本安装
    java中Arraylist复制方法
    java/python中的队列
    java中的函数参数
    linux命令
    python爬某个网站的图片
  • 原文地址:https://www.cnblogs.com/Lilwhat/p/12588037.html
Copyright © 2011-2022 走看看