一、简单使用例子:

这里使用commons.dbcp:

beanx.xml配置:

<?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"
       xmlns:aop="http://www.springframework.org/schema/aop"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
           http://www.springframework.org/schema/beans/spring-beans-2.5.xsd
           http://www.springframework.org/schema/context
           http://www.springframework.org/schema/context/spring-context-2.5.xsd
           http://www.springframework.org/schema/aop
           http://www.springframework.org/schema/aop/spring-aop-2.5.xsd">
           
    <context:annotation-config />
    <context:component-scan base-package="com.cy"/>
    
    <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
      <property name="driverClassName" value="com.mysql.jdbc.Driver"/>
      <property name="url" value="jdbc:mysql://localhost:3306/spring"/>
      <property name="username" value="root"/>
      <property name="password" value="root"/>
    </bean>
    
    <bean id="logInteceptor" class="com.cy.aop.LogInterceptor"></bean>
    
    <aop:config>
        <aop:aspect id="logAspect" ref="logInteceptor">
            <aop:before method="before" pointcut="execution(public * com.cy.service..*.add(..))"/>
        </aop:aspect>
    </aop:config>
    
 
</beans>

userdao实现类UserDAOImpl.java:

将dataSource注入到dao的实现:

package com.cy.dao.impl;

import java.sql.Connection;
import java.sql.SQLException;

import javax.annotation.Resource;
import javax.sql.DataSource;

import org.springframework.stereotype.Component;

import com.cy.dao.UserDAO;
import com.cy.model.User;

@Component
public class UserDAOImpl implements UserDAO {
    
    //resource默认注入方式by name
    @Resource
    private DataSource dataSource;
    
    public void save(User user) {
        try {
            Connection conn = dataSource.getConnection();
            conn.createStatement().executeUpdate("insert into user values (null, 'zhangsan', '123456')");
            conn.close();
        } catch (SQLException e) {
            e.printStackTrace();
        }
        
        System.out.println("user saved!");
    }

}

其他类,和上一章中使用的一摸一样;

引入dbcp相关jar包、mysql驱动包:

马士兵Spring-dataSource

 

测试代码:

package com.cy.service;

import org.junit.Test;
import org.springframework.context.support.ClassPathXmlApplicationContext;

import com.cy.model.User;

public class UserServiceTest {
    
    @Test
    public void testAdd() throws Exception {
        ClassPathXmlApplicationContext ctx = new ClassPathXmlApplicationContext("beans.xml");
        UserService service = (UserService)ctx.getBean("userService");
        System.out.println(service.getClass());
        service.add(new User());
        ctx.destroy();
    }
}
View Code

相关文章:

  • 2021-06-05
  • 2021-08-05
  • 2021-08-24
  • 2021-04-29
  • 2022-12-23
  • 2021-05-07
  • 2021-05-26
  • 2022-12-23
猜你喜欢
  • 2021-08-22
  • 2021-10-03
  • 2021-07-10
  • 2021-12-30
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
相关资源
相似解决方案