服装网站建设企业需求调查,网站交易,学校网站建设建议,查询工程建设项目的网站1.Spring配置数据源1.1 数据源#xff08;连接池#xff09;的作用 数据源(连接池)是提高程序性能如出现的事先实例化数据源#xff0c;初始化部分连接资源使用连接资源时从数据源中获取使用完毕后将连接资源归还给数据源常见的数据源(连接池)#xff1a;DBCP、C3P0、BoneC…1.Spring配置数据源1.1 数据源连接池的作用 数据源(连接池)是提高程序性能如出现的事先实例化数据源初始化部分连接资源使用连接资源时从数据源中获取使用完毕后将连接资源归还给数据源常见的数据源(连接池)DBCP、C3P0、BoneCP、Druid等开发步骤①导入数据源的坐标和数据库驱动坐标②创建数据源对象③设置数据源的基本连接数据④使用数据源获取连接资源和归还连接资源1.2 数据源的手动创建①导入c3p0和druid的坐标!-- C3P0连接池 --
dependencygroupIdc3p0/groupIdartifactIdc3p0/artifactIdversion0.9.1.2/version
/dependency
!-- Druid连接池 --
dependencygroupIdcom.alibaba/groupIdartifactIddruid/artifactIdversion1.1.10/version
/dependency①导入mysql数据库驱动坐标导入数据库我的配置!-- 我自己的版本--dependencygroupIdmysql/groupIdartifactIdmysql-connector-java/artifactIdversion8.0.30/version/dependency!-- mysql驱动 --
dependencygroupIdmysql/groupIdartifactIdmysql-connector-java/artifactIdversion5.1.39/version
/dependency②创建C3P0连接池Test
public void testC3P0() 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);
}②创建Druid连接池Test
public void testDruid() 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);//获得连接对象Connection connection dataSource.getConnection(); System.out.println(connection);
}③提取jdbc.properties配置文件jdbc.drivercom.mysql.cj.jdbc.Driver
jdbc.urljdbc:mysql://localhost:3306/test_spring
jdbc.usernameroot
jdbc.password123321我的配置:④读取jdbc.properties配置文件创建连接池Test
public void testC3P0ByProperties() throws Exception {//加载类路径下的jdbc.propertiesResourceBundle rb ResourceBundle.getBundle(jdbc);ComboPooledDataSource dataSource new ComboPooledDataSource(); dataSource.setDriverClass(rb.getString(jdbc.driver)); dataSource.setJdbcUrl(rb.getString(jdbc.url)); dataSource.setUser(rb.getString(jdbc.username)); dataSource.setPassword(rb.getString(jdbc.password));Connection connection dataSource.getConnection(); System.out.println(connection);
}1.3 Spring配置数据源可以将DataSource的创建权交由Spring容器去完成DataSource有无参构造方法而Spring默认就是通过无参构造方法实例化对象的DataSource要想使用需要通过set方法设置数据库连接信息而Spring可以通过set方法进行字符串注入bean iddataSource classcom.mchange.v2.c3p0.ComboPooledDataSourceproperty namedriverClass valuecom.mysql.jdbc.Driver/property namejdbcUrl valuejdbc:mysql://localhost:3306/test/property nameuser valueroot/property namepassword valueroot/
/bean测试从容器当中获取数据源ApplicationContext applicationContext new ClassPathXmlApplicationContext(applicationContext.xml);DataSource dataSource (DataSource)
applicationContext.getBean(dataSource);
Connection connection dataSource.getConnection();
System.out.println(connection);1.4 抽取jdbc配置文件applicationContext.xml加载jdbc.properties配置文件获得连接信息。首先需要引入context命名空间和约束路径命名空间xmlns:contexthttp://www.springframework.org/schema/context约束路径http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsdcontext:property-placeholder locationclasspath:jdbc.properties/
bean iddataSource classcom.mchange.v2.c3p0.ComboPooledDataSourceproperty namedriverClass value${jdbc.driver}/property namejdbcUrl value${jdbc.url}/property nameuser value${jdbc.username}/property namepassword value${jdbc.password}/
/bean1.5 知识要点 Spring容器加载properties文件context:property-placeholder locationxx.properties/
property name value${key}/2. Spring注解开发【出现问题】Duplicate class found in the file在文件中发现重复的类解决方法给相同名字的类换一个名字。配置结果如下通过注解实现配置2.1 Spring原始注解Spring是轻代码而重配置的框架配置比较繁重影响开发效率所以注解开发是一种趋势注解代替xml配置文件可以简化配置提高开发效率。 Spring原始注解主要是替代的配置注解说明Component使用在类上用于实例化Bean完成对象创建Controller使用在web层类上用于实例化BeanService使用在service层类上用于实例化BeanRepository使用在dao层类上用于实例化BeanAutowired使用在字段上用于根据类型依赖注入对象类型的注入Qualifier结合Autowired一起使用用于根据名称进行依赖注入Resource相当于AutowiredQualifier按照名称进行注入Value注入普通属性普通属性的注入Scope标注Bean的作用范围PostConstruct使用在方法上标注该方法是Bean的初始化方法PreDestroy使用在方法上标注该方法是Bean的销毁方法注意使用注解进行开发时需要在applicationContext.xml中配置组件扫描作用是指定哪个包及其子包下的Bean需要进行扫描以便识别使用注解配置的类、字段和方法。!--注解的组件扫描--
context:component-scan base-packagecom.itheima/context:component-scan使用Compont或Repository标识UserDaoImpl需要Spring进行实例化。//Component(userDao)
Repository(userDao)
public class UserDaoImpl implements UserDao {Overridepublic void save() {System.out.println(save running... ...);}
}使用Compont或Service标识UserServiceImpl需要Spring进行实例化使用Autowired或者AutowiredQulifier或者Resource进行userDao的注入//Component(userService)
Service(userService)
public class UserServiceImpl implements UserService {/*AutowiredQualifier(userDao)*/Resource(nameuserDao)private UserDao userDao;Overridepublic void save() { userDao.save();}
}使用Value进行字符串的注入Repository(userDao)
public class UserDaoImpl implements UserDao {Value(注入普通数据)private String str;Value(${jdbc.driver})private String driver;Overridepublic void save() {System.out.println(str);System.out.println(driver);System.out.println(save running... ...);}
}使用Scope标注Bean的范围//Scope(prototype)
Scope(singleton)
public class UserDaoImpl implements UserDao {//此处省略代码
}使用PostConstruct标注初始化方法使用PreDestroy标注销毁方法PostConstruct
public void init(){System.out.println(初始化方法....);
}
PreDestroy
public void destroy(){System.out.println(销毁方法.....);
}2.2 Spring新注解使用上面的注解还不能全部替代xml配置文件还需要使用注解替代的配置如下非自定义的Bean的配置加载properties文件的配置context:property-placeholder组件扫描的配置context:component-scan引入其他文件注解说明Configuration用于指定当前类是一个 Spring 配置类当创建容器时会从该类上加载注解ComponentScan用于指定 Spring 在初始化容器时要扫描的包。 作用和在 Spring 的 xml 配置文件中的 一样Bean使用在方法上标注将该方法的返回值存储到 Spring 容器中PropertySource用于加载.properties 文件中的配置Import用于导入其他配置类一开始我的代码 Bean(dataSource) //Spring会将当前方法的返回值以指定名称存储到spring容器中
public DataSource getDataSource() throws PropertyVetoException {ComboPooledDataSource dataSource new ComboPooledDataSource();
// 基本连接参数dataSource.setDriverClass(com.mysql.cj.jdbc.Driver);dataSource.setJdbcUrl(jdbc:mysql://localhost:3306/test_spring);dataSource.setUser(root);dataSource.setPassword(123321);return dataSource;
}ConfigurationComponentScanImportConfiguration
ComponentScan(com.itheima)
Import({DataSourceConfiguration.class})
public class SpringConfiguration {
}PropertySourcevaluePropertySource(classpath:jdbc.properties)
public class DataSourceConfiguration {Value(${jdbc.driver})private String driver;Value(${jdbc.url})private String url;Value(${jdbc.username})private String username;Value(${jdbc.password})private String password;BeanBean(namedataSource)
public DataSource getDataSource() throws PropertyVetoException { ComboPooledDataSource dataSource new ComboPooledDataSource(); dataSource.setDriverClass(driver);dataSource.setJdbcUrl(url);dataSource.setUser(username);dataSource.setPassword(password);return dataSource;
} 测试加载核心配置类创建Spring容器Test
public void testAnnoConfiguration() throws Exception {
ApplicationContext applicationContext new AnnotationConfigApplicationContext(SpringConfiguration.class); UserService userService (UserService) applicationContext.getBean(userService);userService.save();DataSource dataSource (DataSource) applicationContext.getBean(dataSource);Connection connection dataSource.getConnection(); System.out.println(connection);}3. Spring整合Junit3.1 原始Junit测试Spring的问题在测试类中每个测试方法都有以下两行代码 ApplicationContext ac new ClassPathXmlApplicationContext(bean.xml);IAccountService as ac.getBean(accountService,IAccountService.class);第一行代码获得应用上的对象第二行代码获得对应的要被测试的对象这两行代码的作用是获取容器如果不写的话直接会提示空指针异常。所以又不能轻易删掉。3.2 上述问题解决思路让SpringJunit负责创建Spring容器但是需要将配置文件的名称告诉它将需要进行测试Bean直接在测试类中进行注入3.3 Spring集成Junit步骤①导入spring集成Junit的坐标②使用Runwith注解替换原来的运行期③使用ContextConfiguration指定配置文件或配置类④使用Autowired注入需要测试的对象⑤创建测试方法进行测试3.4 Spring集成Junit代码实现①导入spring集成Junit的坐标!--此处需要注意的是spring5 及以上版本要求 junit 的版本必须是 4.12 及以上--
dependencygroupIdorg.springframework/groupIdartifactIdspring-test/artifactIdversion5.0.2.RELEASE/version
/dependency
dependencygroupIdjunit/groupIdartifactIdjunit/artifactIdversion4.12/versionscopetest/scope
/dependency②使用Runwith注解替换原来的运行期RunWith(SpringJUnit4ClassRunner.class)
public class SpringJunitTest {
}③使用ContextConfiguration指定配置文件或配置类RunWith(SpringJUnit4ClassRunner.class)
//加载spring核心配置文件
//ContextConfiguration(value {classpath:applicationContext.xml})
//加载spring核心配置类
ContextConfiguration(classes {SpringConfiguration.class})
public class SpringJunitTest {
}④使用Autowired注入需要测试的对象RunWith(SpringJUnit4ClassRunner.class)
ContextConfiguration(classes {SpringConfiguration.class})
public class SpringJunitTest {Autowiredprivate UserService userService;
}⑤创建测试方法进行测试RunWith(SpringJUnit4ClassRunner.class)
ContextConfiguration(classes {SpringConfiguration.class})public class SpringJunitTest {Autowiredprivate UserService userService;Testpublic void testUserService(){userService.save();}
}Spring集成Junit步骤①导入spring集成Junit的坐标②使用Runwith注解替换原来的运行期③使用ContextConfiguration指定配置文件或配置类④使用Autowired注入需要测试的对象⑤创建测试方法进行测试