1、【纯注解配置实现】

首先实现纯注解配置的第一件事情就是删除XML文件

然后编写一个类用于代替XML文件实现配置功能:

使用@Configuration将这个类注册为Spring容器

使用@ComponentScan表示我们自己的包目录扫描

扫描的类会被这个配置注册成Bean,一般那些类会被标记有叶子

使用@PropertySource指定配置文件路径

文件内的信息可以被表达式获取到

使用@Bean注册

用于jar包的资源获取,XML我们使用的是bean标签

当然还需要以一个方法的形式返回:

方法的名字就是Bean的ID属性,方法的返回类型即Class属性

如果我们不想使用方法的名字,可以对Bean再赋值名字的值:

使用@Scope注解改变Bean的范围

当然,如果我们希望这个Bean不是单例的,在XML中则设置scope属性

使用@Import合并配置类

Spring允许我们设置多个配置类,这和设置多个XML配置文件是一样的

在XML文件中我们使用import标签将其他XML文件统一导入到一个文件中,这也是一个道理

例如这里配置了一个Jdbc配置类:

我们就可以把他导入到我们上面的配置类去:

然后我们加载容器实例的时候就不需要分开导入了

注意我们是使用这个注解加载的容器实例:

@Autowired再谈自动装配:

首先自动装配是针对引用数据类型的,例如我们的dao,service,包括一些其他的数据源等对象

基本数据类型,或者说简单的常用数据类型无法使用@Autowired(这种玩意你让Spring装配干嘛,直接赋值不就行了)

还有个要求是被装配的对象所属的类必须也被Spring容器注册了

缺陷:自动装配要求容器中只能有一个符合要求的类型,才可以装配上

如果你注册了多个同类型的bean,该注解无法装配,因为spring不知道你到底需要装配哪一个bean

@Autowired在全注解中的应用:

在bean方法的参数中如果需要注入引用类型,是默认使用自动装配完成的

例如这个例子:

数据源是默认打上了自动装配注解的

使用@Qulifier指定要注入的同类型bean

回到上面的多个同类型的问题,如果我们配置了多个数据源,那么可以在这里添加此注解即可

其意义是指定bean的id属性为注解所指定的相匹配的同类型bean来注入

使用@Value赋值

一般用于对一些类的普通属性进行赋值

这里我为了创建数据源图省事就直接对参数打上注解进行赋值

2、【SpringTest 使用】

为什么需要Spring-Test?

因为Spring容器固定的需要这样手写的方式加载出来:

        ApplicationContext applicationContext = new AnnotationConfigApplicationContext(SpringApplicationConfiguration.class);
QueryRunner queryRunner = applicationContext.getBean("queryRunner", QueryRunner.class);

所以测试的姿势应该更简单些

需要对应的依赖:

特别注意Junit版本不得低于4.12,不然Spring都加载不到

<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.13</version>
<scope>test</scope>
</dependency> <dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-test</artifactId>
<version>5.2.7.RELEASE</version>
</dependency>

然后是测试类的编写:

@Runwith注解测试类使用何种资源运行

@ContextConfiguration用于加载容器配置,一个XML,一个配置类这两种

一个是不要忘记加载容器,第二个是不要加载错误的配置资源

自己写什么配置方式,就加载什么配置资源

代码:

import cn.echo42.config.SpringApplicationConfiguration;
import cn.echo42.pojo.User;
import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.handlers.BeanListHandler;
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; /**
* @author DaiZhiZhou
* @file Spring
* @create 2020-07-27 16:08
*/ @RunWith(SpringJUnit4ClassRunner.class) // 指定运行类
// @ContextConfiguration(locations = "classpath:xxx-context.xml") xml文件加载
@ContextConfiguration(classes = SpringApplicationConfiguration.class) // 配置类加载 指定加载容器
public class SpringTest { @Autowired
private QueryRunner queryRunner; @Test
public void jdbcTest() throws Exception{
for (User user : queryRunner.query("SELECT * FROM `sys_user`", new BeanListHandler<User>(User.class))) {
System.out.println(user);
}
}
}
import cn.echo42.config.SpringApplicationConfiguration;
import cn.echo42.pojo.User;
import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.handlers.BeanListHandler;
import org.junit.Test;
import org.springframework.context.ApplicationContext;
import org.springframework.context.annotation.AnnotationConfigApplicationContext; import java.util.List; /**
* @author DaiZhiZhou
* @file Spring
* @create 2020-07-27 13:43
*/ public class AnnotationTest { @Test
public void annotationGet() throws Exception {
ApplicationContext applicationContext = new AnnotationConfigApplicationContext(SpringApplicationConfiguration.class);
QueryRunner queryRunner = applicationContext.getBean("queryRunner", QueryRunner.class);
System.out.println(queryRunner);
List<User> userList = queryRunner.query("SELECT * FROM `sys_user`", new BeanListHandler<User>(User.class));
for (User user : userList) {
System.out.println(user);
}
}
}
package cn.echo42.config;

import com.alibaba.druid.pool.DruidDataSource;
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.*; import javax.sql.DataSource; /**
* @author DaiZhiZhou
* @file Spring
* @create 2020-07-27 14:37
*/ @Configuration // 表示注解该类为一个配置类
@ComponentScan("cn.echo42") // 指定spring在创建容器时要扫描的包,一般直接扫描总目录
@PropertySource("classpath:jdbc.properties") //指定properties文件的位置
public class SpringApplicationConfiguration { // 在这里引用外部Jar包的资源 @Bean("queryRunner")
@Scope("prototype")
public QueryRunner getQueryRunner(@Qualifier("dataSource") DataSource dataSource){
return new QueryRunner(dataSource);
} @Bean("dataSource") //
public DataSource getDataSource(
@Value("${jdbc.driverClassName}") String driver,
@Value("${jdbc.url}")String url,
@Value("${jdbc.user}")String username,
@Value("${jdbc.password}")String password ) {
DruidDataSource druidDataSource = new DruidDataSource();
druidDataSource.setDriverClassName(driver);
druidDataSource.setUrl(url);
druidDataSource.setUsername(username);
druidDataSource.setPassword(password);
return druidDataSource;
}
}
jdbc.driverClassName = com.mysql.cj.jdbc.Driver
jdbc.url = jdbc:mysql://localhost:3306/oa?serverTimezone=GMT
jdbc.user = root
jdbc.password = 123456

【Spring】08 后续的学习补充 vol2的更多相关文章

  1. 写给大忙人的spring cloud 1.x学习指南

    这几天抽空搞了下spring cloud 1.x(2.0目前应该来说还不成熟),因为之前项目中使用dubbo以及自研的rpc框架,所以总体下来还是比较顺利,加上spring boot,不算笔记整理,三 ...

  2. Spring Cloud微服务学习笔记

    Spring Cloud微服务学习笔记 SOA->Dubbo 微服务架构->Spring Cloud提供了一个一站式的微服务解决方案 第一部分 微服务架构 1 互联网应用架构发展 那些迫使 ...

  3. Spring+SpringMVC+MyBatis深入学习及搭建(二)——MyBatis原始Dao开发和mapper代理开发

    转载请注明出处:http://www.cnblogs.com/Joanna-Yan/p/6869133.html 前面有写到Spring+SpringMVC+MyBatis深入学习及搭建(一)——My ...

  4. Spring+SpringMVC+MyBatis深入学习及搭建(三)——MyBatis全局配置文件解析

    转载请注明出处:http://www.cnblogs.com/Joanna-Yan/p/6874672.html 前面有写到Spring+SpringMVC+MyBatis深入学习及搭建(二)——My ...

  5. Spring+SpringMVC+MyBatis深入学习及搭建(四)——MyBatis输入映射与输出映射

    转载请注明出处:http://www.cnblogs.com/Joanna-Yan/p/6878529.html 前面有讲到Spring+SpringMVC+MyBatis深入学习及搭建(三)——My ...

  6. Spring+SpringMVC+MyBatis深入学习及搭建(五)——动态sql

    转载请注明出处:http://www.cnblogs.com/Joanna-Yan/p/6908763.html 前面有讲到Spring+SpringMVC+MyBatis深入学习及搭建(四)——My ...

  7. Spring+SpringMVC+MyBatis深入学习及搭建(六)——MyBatis关联查询

    转载请注明出处:http://www.cnblogs.com/Joanna-Yan/p/6923464.html 前面有将到:Spring+SpringMVC+MyBatis深入学习及搭建(五)--动 ...

  8. Spring+SpringMVC+MyBatis深入学习及搭建(七)——MyBatis延迟加载

    转载请注明出处:http://www.cnblogs.com/Joanna-Yan/p/6953005.html 前面讲到:Spring+SpringMVC+MyBatis深入学习及搭建(六)——My ...

  9. Spring+SpringMVC+MyBatis深入学习及搭建(八)——MyBatis查询缓存

    转载请注明出处:http://www.cnblogs.com/Joanna-Yan/p/6956206.html 前面讲到:Spring+SpringMVC+MyBatis深入学习及搭建(七)——My ...

  10. Spring+SpringMVC+MyBatis深入学习及搭建(九)——MyBatis和Spring整合

    转载请注明出处:http://www.cnblogs.com/Joanna-Yan/p/6964162.html 前面讲到:Spring+SpringMVC+MyBatis深入学习及搭建(八)--My ...

随机推荐

  1. kettle从入门到精通 第三十八课 kettle 分页全量同步(数据量大)

    1.上一课我们学习了在数据量小的情况下的全量同步示例,本次我们一起学习下kettle 分页全量同步. 2.kettle分页全量同步示例依然基于test数据库,从t1表全量同步数据到t2表,由于t1表的 ...

  2. 使用 Java 客户端通过 HTTPS 连接到 Easysearch

    Easysearch 一直致力于提高易用性,这也是我们的核心宗旨,然而之前一直没有官方的 Java 客户端,也对用户使用造成了一些困扰,现在,我们正式发布了第一个 Java 客户端 Easysearc ...

  3. C#.NET根据不同业务类别类型写入不同文件中,动态创建log4net实例验证

    C#.NET根据不同业务类别类型写入不同文件中,动态创建log4net实例验证 参考了:https://www.cnblogs.com/-dawn/p/8598566.html GetLog4netI ...

  4. Django路由层、视图层及模板层

    Django路由层 URL配置(URLconf)就像Django所支撑网站的目录.它的本质是URL与要为该URL调用的视图函数之间的映射表; 你就是以这种方式告诉Django,对于客户端发来的某个UR ...

  5. Vue学习:18.Vue插槽

    Vue 中的插槽(slot)是一种灵活的机制,用于在父组件中将内容传递到子组件的特定位置.它允许我们在子组件中定义可以在父组件中传递任意内容的"插槽",从而实现更灵活的组件化. 在 ...

  6. js获取指定日期的前一天/后一天

    date代表指定日期,格式:2018-09-27 day代表天数,-1代表前一天,1代表后一天 // date 代表指定的日期,格式:2018-09-27// day 传-1表始前一天,传1表始后一天 ...

  7. work05

    第一题:分析以下需求,并用代码实现 手机类Phone 属性: 品牌brand 价格price 行为: 打电话call() 发短信sendMessage() 玩游戏playGame() 要求: 1.按照 ...

  8. 支付宝签名和验签使用JSONObject是最优解。json字符串顺序和==符号都一致演示代码

    支付宝签名和验签使用JSONObject是最优解.json字符串顺序和==符号都一致演示代码 支付宝spi接口设计验签和返回结果加签注意点,支付宝使用JSONObject对象https://www.c ...

  9. Mysql RC/RR隔离原理和区别 不可重复读和可重复读

    Mysql RC/RR隔离原理和区别 不可重复读和可重复读 mysql四种隔离级别:1.未提交读(READ UNCOMMITED)脏读2.已提交读 (READ COMMITED)简称(RC) 不可重复 ...

  10. Lecture3

    Smiling & Weeping ---- 蝴蝶在双翼里藏匿夏的脉络 妄图在绿意中品鉴隆冬 第三章 Git分支管理 3.1 分支的简介 Git最重要的运用场景是多人协同开发,但是如何能保证每 ...