Spring配置非定义的Bean

前言

  • 在前文中,xml配置文件中的Bean都是我们自己定义配置的,例如:UserDaoImpl,UserDAO等。但是在实际开发过程中有些功能类并不是我们自己定义的,而是使用第三方jar包中的,俺么这些Bean要想让Spring进行管理,也需要对其进行配置。
  • 配置非自定义的Bean需要考虑如下两个问题
    • 被配置的bean的实例化方式是什么?无参构造,有参构造(构造方法),静态工厂方式还是实例工厂方式(工厂方式)。具体见文章:写文章-CSDN创作中心
    • 被配置的Bean是否需要注入必要属性

配置Druid数据源交由Spring管理

  • 导入Druid的maven坐标
    •         <!--    todo    MySQL驱动-->
              <dependency>
                  <groupId>mysql</groupId>
                  <artifactId>mysql-connector-java</artifactId>
                  <version>5.1.49</version>
              </dependency>
      
              <!--    todo    druid 数据源-->
              <dependency>
                  <groupId>com.alibaba</groupId>
                  <artifactId>druid</artifactId>
                  <version>1.1.23</version>
  • 根据Druid类中的set方法来设置必要的属性

  • 配置信息如下


    •  

  • 测试代码

    • package com.example.Test;
      
      import org.springframework.context.support.ClassPathXmlApplicationContext;
      
      public class TestApplicationContext {
          public static void main(String[] args) {
              // 指定环境
              System.setProperty("spring.profiles.active", "dev");
              ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext("application.xml");
              Object dataSource = context.getBean("dataSource");
              System.out.println(dataSource);
          }
      }
      
  • 运行结果


    •  

配置Connection交由Spring管理

  • Connection的产生是通过DriverManager的静态方法getConnection获取的,所以我们要使用静态工厂方式配置
    • 手动建立连接
      •         // 加载驱动
                Class.forName("com.mysql.jdbc.Driver");
                // 建立连接
                Connection connection = DriverManager.getConnection("jdbc:mysql://localhost:3306/db01", "root", "123456");
                System.out.println(connection);
    • 使用配置文件进行建立(静态工厂方法

      •     <bean id="classA" class="java.lang.Class" factory-method="forName">
                <!--        为forName()方法中的参数设定值 name为参数名称,value为参数值-->
                <constructor-arg name="className" value="com.mysql.jdbc.Driver"></constructor-arg>
            </bean>
            <bean id="connection" class="java.sql.DriverManager" factory-method="getConnection">
                <constructor-arg value="jdbc:mysql://localhost:3306/db01" name="url"></constructor-arg>
                <constructor-arg value="自己的" name="user"></constructor-arg>
                <constructor-arg value="自己的" name="password"></constructor-arg>
            </bean>
    • 测试代码

      • package com.example.Test;
        
        import org.springframework.context.support.ClassPathXmlApplicationContext;
        
        
        public class TestApplicationContext {
            public static void main(String[] args) {
                ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext("application.xml");
                System.out.println(context.getBean("connection"));
            }
        }
        
    • 运行结果

配置日期对象交由Spring管理

  • 原始代码如下
    •         SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yy-MM-dd HH:mm:ss");
              Date date = simpleDateFormat.parse("2023-08-27 07:20:00");
  • 配置文件(实例工厂方法

    •     <bean id="simpleDateFormat" class="java.text.SimpleDateFormat">
              <constructor-arg name="pattern" value="yy-MM-dd HH:mm:ss"></constructor-arg>
          </bean>
          <bean id="date" factory-bean="simpleDateFormat" factory-method="parse">
              <constructor-arg name="source" value="2023-08-27 07:20:00"></constructor-arg>
          </bean>
  • 测试类

    • package com.example.Test;
      
      import org.springframework.context.support.ClassPathXmlApplicationContext;
      
      
      public class TestApplicationContext {
          public static void main(String[] args) {
              ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext("application.xml");
              System.out.println(context.getBean("date"));
      
          }
      }
      
  • 运行结果

配置MyBatis的SqlSqlSessionFactory交由Spring管理

  • 导入MyBatis的maven坐标
    • <dependency>
          <groupId>org.mybatis</groupId>
          <artifactId>mybatis</artifactId>
          <version>3.5.8</version>
      </dependency>
      
  • 代码配置

    •         // 静态工厂方法
              InputStream resourceAsStream = Resources.getResourceAsStream("MyBatisConfig.xml");
              // 无参构造
              SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();
              // 实例工厂方法
              SqlSessionFactory build = builder.build(resourceAsStream);
      
  • 配置文件

    •     <!--    todo 无参构造-->
          <bean id="builder" class="org.apache.ibatis.session.SqlSessionFactoryBuilder"></bean>
          <!--  todo   静态工厂方法-->
          <bean id="resources" class="org.apache.ibatis.io.Resources" factory-method="getResourceAsStream">
              <constructor-arg value="MyBatisConfig.xml" name="resource"></constructor-arg>
          </bean>
          <!-- todo 实例化工厂方法-->
          <bean id="build" factory-bean="builder" factory-method="build">
              <constructor-arg name="inputStream" ref="resources"></constructor-arg>
          </bean>
  • 测试代码

    • package com.example.Test;
      
      
      import org.springframework.context.support.ClassPathXmlApplicationContext;
      
      
      
      public class TestApplicationContext {
          public static void main(String[] args)  {
              ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext("application.xml");
              System.out.println(context.getBean("build"));
      
      
          }
      }
      
  • 运行结果

小结

  • 对于配置非自定义的bean,首先得了解它是由什么方法创建的bean对象,具体文章参考:写文章-CSDN创作中心
  • 确定是哪一种方式之后就可以按照固定的套路来进行bean的配置了 
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值