IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Java知识库 -> 【框架】---->Spring 02 (IOC的实现) -> 正文阅读

[Java知识库]【框架】---->Spring 02 (IOC的实现)


一、配置数据源

数据源(连接池)的作用

1、数据源是为了提高程序性能而出现的
2、事先实例化数据源,初始化部分连接资源
3、使用连接资源时从数据源中获取
4、使用完毕后将连接资源归还给数据源

常见的数据源:DBCP、C3P0、BoneCP、Druid等

数据源的开发步骤

1、导入数据源的坐标和数据库驱动坐标

 <dependencies>
     <dependency>
         <groupId>mysql</groupId>
         <artifactId>mysql-connector-java</artifactId>
         <version>5.1.32</version>
     </dependency>
     <dependency>
         <groupId>c3p0</groupId>
         <artifactId>c3p0</artifactId>
         <version>0.9.1.2</version>
     </dependency>
     <dependency>
         <groupId>com.alibaba</groupId>
         <artifactId>druid</artifactId> 
         <version>1.1.10</version>
     </dependency>
     <dependency>
         <groupId>junit</groupId>
         <artifactId>junit</artifactId>
         <version>4.13.1</version>
         <scope>test</scope>
     </dependency>
 </dependencies>

2、创建数据源对象
3、设置数据源的基本连接数据
4、使用数据源获取连接资源和归还连接资源

数据源的手动创建

public class DataSourceTest {
    @Test
    //测试手动创建 c3p0 数据源
    public void test1() throws Exception {
        ComboPooledDataSource dataSource = new ComboPooledDataSource();
        //设置基本的连接参数
        dataSource.setDriverClass("com.mysql.jdbc.Driver");
        dataSource.setJdbcUrl("jdbc:mysql://localhost:3306/test");
        dataSource.setUser("root");
        dataSource.setPassword("root");
        //获取资源
        Connection connection = dataSource.getConnection();
        System.out.println(connection);
        //归还到数据源
        connection.close();
    }
    @Test
    //测试手动创建 durid 数据源
    public void test2() throws Exception {
        DruidDataSource dataSource=new DruidDataSource();
        //设置基本的连接参数
        dataSource.setDriverClassName("com.mysql.jdbc.Driver");
        dataSource.setUrl("jdbc:mysql://localhost:3306/test");
        dataSource.setUsername("root");
        dataSource.setPassword("root");
        //获取资源
        DruidPooledConnection connection = dataSource.getConnection();
        System.out.println(connection);
        //归还到数据源
        connection.close();
    }
}

抽取jdbc配置文件

目的:方便解耦

创建jdbc.properties文件内容如下:

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

测试手动创建 c3p0 数据源(加载jdbc.properties配置文件):

   @Test
    //测试手动创建 c3p0 数据源(加载jdbc.properties配置文件)
    public void test3() throws Exception {
        //读取配置文件
        ResourceBundle rb = ResourceBundle.getBundle("jdbc");//jdbc.properties的基本名称
        String driver = rb.getString("jdbc.driver");
        String url = rb.getString("jdbc.url");
        String username = rb.getString("jdbc.username");
        String password = rb.getString("jdbc.password");
        //创建数据源对象 设置连接参数
        ComboPooledDataSource dataSource = new ComboPooledDataSource();
        dataSource.setDriverClass(driver);
        dataSource.setJdbcUrl(url);
        dataSource.setUser(username);
        dataSource.setPassword(password);
        //获取资源
        Connection connection = dataSource.getConnection();
        System.out.println(connection);
        //归还到数据源
        connection.close();
    }

二、 Spring配置数据源

可以将DataSource的创建权交由Spring容器去完成。
第一步:导入Spring的坐标

 <dependency>
         <groupId>org.springframework</groupId>
         <artifactId>spring-context</artifactId>
         <version>5.0.5.RELEASE</version>
     </dependency>

第二步:创建核心文件

  <!--    ComboPooledDataSource dataSource = new ComboPooledDataSource();-->
    <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
        <!-- 注入参数 -->
        <property name="driverClass" value="com.mysql.jdbc.Driver"/>
        <property name="jdbcUrl" value="jdbc:mysql://localhost:3306/test"/>
        <property name="user" value="root"/>
        <property name="password" value="root"/>
    </bean>

第三步:测试Spring容器去产生数据源对象

   @Test
    //测试Spring容器去产生数据源对象
    public void test4() throws Exception {
        ApplicationContext app = new ClassPathXmlApplicationContext("applicationContex.xml");
       // app.getBean("dataSource");
        DataSource dataSource = app.getBean(DataSource.class);
        //获取资源
        Connection connection = dataSource.getConnection();
        System.out.println(connection);
        connection.close();
    }

抽取jdbc配置文件

??applicationContext.xml加载jdbc.properties配置文件获得连接信息。
引入context命名空间和约束路径:

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       //命名空间
       xmlns:context="http://www.springframework.org/schema/context"
       xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
       						//约束路径
                            http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd">

    <!--加载外部的properties文件-->
    <context:property-placeholder location="jdbc.properties"/>
    <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
        <!-- 注入参数 -->
        <property name="driverClass" value="${jdbc.driver}"/>
        <property name="jdbcUrl" value="${jdbc.url}"/>
        <property name="user" value="${jdbc.username}"/>
        <property name="password" value="${jdbc.password}"/>
    </bean>
</beans>

在这里插入图片描述

三、注解开发

按例1:未用注解用配置文件进行配置
第一步:创建Dao层
Dao接口略
接口实现类:

public class UserDaoimpl implements UserDao {
    @Override
    public void save() {
        System.out.println("..........");
    }
}

第二步:创建Service层
Service接口略
接口实现类:

public class UserServiceimpl implements UserService {
    private UserDao userDao;

    public void setUserDao(UserDao userDao) {
        this.userDao = userDao;
    }

    @Override
    public void save() {
        userDao.save();
    }
}

第三步:xml配置文件配置:

 <bean id="userDao" class="com.dao.impl.UserDaoimpl"></bean>
    <bean id="userService" class="com.service.impl.UserServiceimpl">
        <property name="userDao" ref="userDao"/>
    </bean>

第四步:web层实现

public class UserController {
    public static void main(String[] args) {
        ApplicationContext app = new ClassPathXmlApplicationContext("applicationContex.xml");
        UserService userService = app.getBean(UserService.class);
        userService.save();
    }
}

??Spring是轻代码而重配置的框架,配置比较繁重,影响开发效率,所以注解开发是一种趋势,注解代替xml配置文件可以简化配置,提高开发效率。

Spring的原始注解

Spring原始注解主要是替代< Bran>的配置。
在这里插入图片描述
按例2:利用注解方式对按例1进行优化
Dao接口实现类:

// <bean id="userDao" class="com.dao.impl.UserDaoimpl"></bean>
@Component("userDao")
public class UserDaoimpl implements UserDao {
    @Override
    public void save() {
        System.out.println("..........");
    }
}

Serivce接口实现类:

//<bean id="userService" class="com.service.impl.UserServiceimpl">
@Component("userService")
public class UserServiceimpl implements UserService {
    //<property name="userDao" ref="userDao"/>
    @Autowired//自动注入
    @Qualifier("userDao")
    private UserDao userDao;
    public void setUserDao(UserDao userDao) {
        this.userDao = userDao;
    }
    @Override
    public void save() {
        userDao.save();
    }
}

??使用注解进行开发时,需要在applicationContext.xml中配置组件扫描,作用是指定哪个包及其子包下的Bean需要进行扫描以便识别使用注解配置的类、字段和方法。

配置文件配置:

 <!--配置组件扫描-->
 	//com:基础包
    <context:component-scan base-package="com"></context:component-scan>

注意:注解可以根据所在层的不同进行更改

Spring的新注解

按例2可知使用旧注解不能全部替代xml配置文件,还需要使用注解替代的配置如:

1、非自定义的Bean的配置:< bean>
2、加载properties文件的配置:< context:property-placeholder>
3、组件扫描的配置:< context:component-scan>
4、引入其他文件:< import>

在这里插入图片描述
按例3:对按例2进行改进:
创建一个配置类,对xml中的配置信息进行配置,以替代xml:

//标志该类是Spring的核心配置类
@Configuration
//配置组件扫描
@ComponentScan("com")
@PropertySource("jdbc.properties")
public class SpringCofiguration {
    @Value("${jdbc.driver}")
    private String driver;
    @Value("${jdbc.url}")
    private String url;
    @Value("${jdbc.username}")
    private String name;
    @Value("${jdbc.password}")
    private String password;

    @Bean("dataSource")//Spring会将当前方法的返回值以指定名称存储到Spring容器中
    public DataSource getDataSource() throws PropertyVetoException {
        ComboPooledDataSource dataSource = new ComboPooledDataSource();
        //设置基本的连接参数
        dataSource.setDriverClass(driver);
        dataSource.setJdbcUrl(url);
        dataSource.setUser(name);
        dataSource.setPassword(password);
        return dataSource;
    }
}

web层测试代码:

public class UserController {
    public static void main(String[] args) {
        ApplicationContext app = new AnnotationConfigApplicationContext(SpringCofiguration.class);
        UserService userService = app.getBean(UserService.class);
        userService.save();
    }
}

四、Spring整合Junit

原始Junit测试Spring的问题

在测试类中,每个测试方法都有这两行代码:
在这里插入图片描述
解决思路:
?? 1、让SpringJunit负责创建Spring容器,但是需要将配置文件的名称告诉它
?? 2、将需要进行测试Bean直接在测试类中进行注入。

Spring集成Junit步骤

1、导入Spring集成Junit的坐标
 <dependency>
         <groupId>org.springframework</groupId>
         <artifactId>spring-test</artifactId>
         <version>5.0.5.RELEASE</version>
     </dependency>
2、使用@Runwith注解替换原来的运行期
3、使用@ContextConfiguration指定配置文件或配置类
4、使用@Autowired注入需要测试的对象
5、创建测试方法进行测试

创建测试类:

@RunWith(SpringJUnit4ClassRunner.class)
//@ContextConfiguration("classpath:applicationContex.xml")
@ContextConfiguration(classes = {SpringCofiguration.class})
public class SpringJunitTest {
    @Autowired
    private UserService userService;
    @Test
    public void test1() {
        userService.save();
    }
}
  Java知识库 最新文章
计算距离春节还有多长时间
系统开发系列 之WebService(spring框架+ma
springBoot+Cache(自定义有效时间配置)
SpringBoot整合mybatis实现增删改查、分页查
spring教程
SpringBoot+Vue实现美食交流网站的设计与实
虚拟机内存结构以及虚拟机中销毁和新建对象
SpringMVC---原理
小李同学: Java如何按多个字段分组
打印票据--java
上一篇文章      下一篇文章      查看所有文章
加:2022-05-21 18:48:02  更:2022-05-21 18:49:37 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/27 22:23:21-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码