Spring知识点小结(二)
一、配置非自定义的Bean(数据源DataSource模型)
DBCP数据源:
导入dbcp的jar包:dbcp+pool+connector
代码实现:
//创建数据源对象
BasicDataSource dataSource = new BasicDataSource();
//设置数据库的基本参数
dataSource.setDriverClassName("com.mysql.jdbc.Driver");
dataSource.setUrl("jdbc:mysql:///test");
dataSource.setUsername("****");
dataSource.setPassword("****");
//从数据源中获得连接资源
Connection connection = dataSource.getConnection();
//jdbc操作
System.out.println(connection);
C3P0数据源:
导入c3p0的jar包:c3p0+connector
代码实现:
//创建数据源对象
ComboPooledDataSource dataSource = new ComboPooledDataSource();
//设置数据库的基本参数
dataSource.setDriverClass("com.mysql.jdbc.Driver");
dataSource.setJdbcUrl("jdbc:mysql:///test");
dataSource.setUser("****");
dataSource.setPassword("****");
//从数据源中获得连接资源
Connection connection = dataSource.getConnection();
//jdbc操作
System.out.println(connection);
在spring中配置数据源对象:
<!-- 将jdbc.properties文件加载到spring的容器中 需要用到context命名空间
classpath:类加载路径 开发环境下就是src
-->
<context:property-placeholder location="classpath:jdbc.properties"/>
<!-- 配置c3p0数据源 -->
<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
<property name="driverClass" value="${jdbc.driver}"></property>
<property name="jdbcUrl" value="${jdbc.url}"></property>
<property name="user" value="${jdbc.username}"></property>
<property name="password" value="${jdbc.password}"></property>
</bean>
二、Spring的注解开发
注解与xml配置文件的优缺点?
xml优点:解耦合 缺点:配置繁琐
注解优点:快 缺点:耦合
1、Spring原始注解
出现的目的主要是对自定义的Bean的xml配置的替代
1.1开发步骤:
1、导入额外jar:spring-aop.jar
2、在xml中开启组件扫描
<!-- 组件扫描:告知spring容器哪些包下的bean需要被扫描 -->
<context:component-scan base-package="com.cyxz"></context:component-scan>
3、在实体Bean上使用注解进行开发
@Component("customerDao")
public class CustomerDaoImpl implements CustomerDao
@Component("customerService")
public class CustomerServiceImpl implements CustomerService
@Autowired
private CustomerDao customerDao;
4、测试
1.2 注解的详解
IoC:创建对象
@Component(该Bean对象的标识/id):在需要被spring进行实例化Bean上,参数字符串可以不写,默认是当前类名的首字母小写
@Controller:控制器 使用web层的Bean上 例如Action
@Service:服务 使用service层的Bean 例如CustomerServiceImpl
@Repository: 仓库 使用dao层的Bean上 例如CustomerDaoImpl
DI:依赖注入,注解的注入可以省略set方法
@Autowired:自动按照实体的类型进行注入
@Qualifier("customerDao") //此处@Qualifier是按照名称匹配 但是在此处@Qualifier结合@Autowired一起使用
@Resource(name="customerDao") //@Resource=@Autowired+@Qualifier
@Value(值)
其他:
@Scope:配置bean的作用范围,取值singleton(默认)和prototype 注解配置默认是prototype,xml配置默认是singleton
@PostConstruct:指定初始化方法 //在构造之后执行
PreDestroy:指定销毁方法 //在销毁之前执行
注意;重点注解:@Controller、@Service、@Repository、@Autowired、@Scope
注意:开发准则:Bean是自定义那么使用注解配置、Bean是非自定义的那么使用xml配置
2、Spring新注解(次重点)
Spring的新注解出现的目的完全替代xml配置文件
使用配置类 替代 xml文件
使用注解 替代 标签
@Configuration //标注该类是一个spring的配置类
@ComponentScan("com.cyxz") //组件扫描
@Import({DataSourceConfiguration.class}) //引入其他的配置类
@PropertySource({"classpath:jdbc.properties"}) //加载jdbc.properties文件
@Value("${jdbc.driver}") //匹配spring容器中的key
@Bean(name="dataSource") //将该方法的返回值以指定的名称存储到spring容器中
三、Spring集成Junit
原有的测试类:
@Test
//测试从spring中获得Service实例对象
public void test1() throws Exception{
ApplicationContext app = new ClassPathXmlApplicationContext("applicationContext.xml");
CustomerService customerService = (CustomerService) app.getBean("customerService");
customerService.save();
}
spring集成junit:
开发步骤:
1、导入额外的jar
spring-test.jar
spring-aop.jar
junit.jar
2、通过注解的形式指定测试类 和 配置文件
执行测试类:@RunWith(SpringJUnit4ClassRunner.class)
指定配置文件(类):@ContextConfiguration("classpath:applicationContext.xml")
3、测试spring容器中的哪个对象就通过注解注入哪个对象
4、编写测试方法
代码实现:
@RunWith(SpringJUnit4ClassRunner.class)
//@ContextConfiguration("classpath:applicationContext.xml") //加载配置文件
@ContextConfiguration(classes={SpringConfiguration.class}) //加载配置类
public class SpringJunitTest {
@Autowired
private CustomerDao customerDao;
@Autowired
private CustomerService customerService;
@Test
public void test1(){
customerDao.save();
}
@Test
public void test2(){
customerService.save();
}
}
Spring知识点小结(二)的更多相关文章
- Spring知识点小结(四)
一.JdbcTemplate(jdbc模版--抽取的工具) web阶段DBUtils: QueryRunner runner = new QueryRunner(dataSource); ...
- Spring知识点小结(三)
一.aop的简介 aop:面向切面编程 aop是一种思想,面向切面编程思想,Spring内部提供了组件对aop进行实现 aop是在运行期间使用动态代理技术实现的思想 aop是oop延 ...
- Spring知识点小结(一)
一.Spring的简介 1.spring是一个full-stack轻量级开源框架 2.spring的两大核心 IoC: inverse of control 控制反转:反转是对象 ...
- Spring知识点小结汇总
Spring部分 1.谈谈你对spring IOC和DI的理解,它们有什么区别? IoC Inverse of Control 反转控制的概念,就是将原本在程序中手动创建UserService对象的控 ...
- Spring知识点总结(二)之Spring IOC
1.创建bean类,并在spring中进行配置交由spring来管理1. IOC(DI) - 控制反转(依赖注入) 所谓的IOC称之为控制反转,简单来说就是将对象的创建的权利及对象的生命周期的管 ...
- Hibernate知识点小结(二)
一.持久化对象和标识符 1.持久化类 配置完关系后,操作的实体对应的类,成为持久化类 (Customer) 2.持久化类标识符(oid:object id) 3.持久 ...
- Struts2知识点小结(二)
一.结果视图的配置 <result name="success">/success.jsp</result> 1.局部结果视图 ...
- SpringBoot 系列教程之事务隔离级别知识点小结
SpringBoot 系列教程之事务隔离级别知识点小结 上一篇博文介绍了声明式事务@Transactional的简单使用姿势,最文章的最后给出了这个注解的多个属性,本文将着重放在事务隔离级别的知识点上 ...
- disruptor笔记之四:事件消费知识点小结
欢迎访问我的GitHub https://github.com/zq2599/blog_demos 内容:所有原创文章分类汇总及配套源码,涉及Java.Docker.Kubernetes.DevOPS ...
随机推荐
- C语言函数指针(指向函数的指针)
转载:http://c.biancheng.net/cpp/html/3248.html 一个函数总是占用一段连续的内存区域,函数名在表达式中有时也会被转换为该函数所在内存区域的首地址,这和数组名非常 ...
- LUHN算法
LUHN算法,主要用来计算信用卡等证件号码的合法性. 1.从卡号最后一位数字开始,偶数位乘以2,如果乘以2的结果是两位数,将两个位上数字相加保存. 2.把所有数字相加,得到总和. 3.如果信用卡号码是 ...
- Python学习---重点模块之re
正则表达式是用来操作字符串,但是字符串提供的正则是完全匹配,有时候我们需要进行模糊匹配,这个时候就需要正则表达式了.通过re模块来实现,由C语言来执行底层的匹配 字符匹配(普通字符,元字符): 1 普 ...
- 使用mysli防止sql注入
自从 php5 推出 mysqli 后就开始不提倡使用 mysql_ 开头的接口了,现在使用 mysql_connet 通常调试的时候会报警告说这个不该用 mysqli 使用起来其实更简单 $url ...
- yii2.0表单自带验证码
Yii2.0的自带的验证依赖于GD2或者ImageMagick扩展. 使用步骤如下: 第一步,控制器: 在任意controller里面重写方法
- jQuery插件开发精品教程,让你的jQuery提升一个台阶(转)
原文:http://www.cnblogs.com/Wayou/p/jquery_plugin_tutorial.html 要说jQuery 最成功的地方,我认为是它的可扩展性吸引了众多开发者为其开发 ...
- SAP Cloud for Customer Account和individual customer的区别
在SAP Cloud for Customer的Customers工作中心里,有三个视图:Accounts,Contacts和Individual Customers. 这三种主数据的区别是什么?我们 ...
- SAP Cloud for Customer Sales Order Requested Date的业务含义和实现
我们在创建Sales order销售订单时,需要指定一个RequestedDate: 这个字段绑定到了BO字段:CustomerQuote.RequestedFulfillmentPeriod.Tim ...
- Python迭代(入门8)
转载请标明出处: http://www.cnblogs.com/why168888/p/6407980.html 本文出自:[Edwin博客园] Python迭代 1. 什么是迭代 注意: 集合是指包 ...
- 从数据库反向生成django的models
有办法实现django 数据库反向生成models的方法吗?答案是肯定的. 1. 配置 settings.py 中的数据库配置部分 DATABASES = { 'default': { 'ENGINE ...