配置文件一般放在resource里面 防止到哪里都不影响
- 准备所需的jar包
在pom.xml文件中导入jar包
Maven repository中搜索jar包 粘贴进pom中 要求版本一致
其中基础的jar包包括:
Mybatis log4j MySQL commons-dbcp2数据云
pom.xml
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>bzu.com</groupId>
<artifactId>PersonManagement</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>war</packaging>
<dependencies>
<!-- https://mvnrepository.com/artifact/org.apache.commons/commons-dbcp2 -->
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-dbcp2</artifactId>
<version>2.1.1</version>
</dependency>
<!-- spring相关的jar -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-beans</artifactId>
<version>4.3.6.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>4.3.6.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-core</artifactId>
<version>4.3.6.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-expression</artifactId>
<version>4.3.6.RELEASE</version>
</dependency>
<dependency>
<groupId>commons-logging</groupId>
<artifactId>commons-logging</artifactId>
<version>1.2</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-tx</artifactId>
<version>4.3.6.RELEASE</version>
</dependency>
<!-- https://mvnrepository.com/artifact/org.springframework/spring-jdbc -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-jdbc</artifactId>
<version>5.0.8.RELEASE</version>
</dependency>
<!-- springMVC相关的jar -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>4.3.6.RELEASE</version>
</dependency>
<!-- https://mvnrepository.com/artifact/org.springframework/spring-web -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-web</artifactId>
<version>4.3.6.RELEASE</version>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
<version>3.1.0</version>
<scope>provided</scope>
</dependency>
<!-- mybatis相关的jar -->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.5.1</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.38</version>
</dependency>
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.17</version>
</dependency>
<!-- 数据库连接池相关的jar -->
<!-- https://mvnrepository.com/artifact/com.mchange/c3p0 -->
<dependency>
<groupId>com.mchange</groupId>
<artifactId>c3p0</artifactId>
<version>0.9.5.2</version>
</dependency>
<!-- MyBatis和Spring整合JAR -->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis-spring</artifactId>
<version>1.3.1</version>
</dependency>
</dependencies>
</project>
- 创建一个applicationContent.xml文件
组件 beans 整合之后 代替Mybatis文件 其中包括数据库环境的配置等 - 引入db.properties文件
引入context配置空间才能使用context
<!-- 读取db.properties -->
<context:property-placeholder location="classpath:db.properties"/>
- 配置数据源
Id 为唯一标识 class 需要网络上搜索
C3P0 与 dbcp2都可以
<!-- 配置数据源 -->
<bean id="dataSource" class="org.apache.commons.dbcp2.BasicDataSource">
<property name="driverClassName" value="${jdbc.driver}"></property>
<property name="url" value="${jdbc.url}"></property>
<property name="username" value="${jdbc.username}"></property>
<property name="password" value="${jdbc.userpass}"></property>
<property name="maxTotal" value="${jdbc.maxTotal}"></property>
<property name="maxIdle" value="${jdbc.maxIdle}"></property>
<property name="initialSize" value="${jdbc.initialSize}"></property>
</bean>
- 新建file文件 命名为db.properties
将数据源中的相关配置拿到db.properties 中
则数据源中获取的值为 ${jdbc.driverClass}等
(这里我用的数据库为dbcp2,所以db.properties的写法与c3p0不太一样,)
jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/person_management
jdbc.username=root
jdbc.userpass=123456
jdbc.maxTotal=30
jdbc.maxIdle=10
jdbc.initialSize=5
- 配置事物管理器,依赖于数据源
配置唯一标识id ,class
运用ref 指向同文件中的数据源信息
<!-- 配置事务管理器,依赖于数据源 -->
<bean id="transationManager"
class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource"></property>
</bean>
- 使用注解配置 所以要开启事物注解支持
引入tx事物注解的支持 在Namespace里面勾选tx
需要移入事物管理器支持 transation-manager
<!-- 开启事务注解 -->
<tx:annotation-driven transaction-manager="transationManager"/>
- 配置MyBatis工厂sqlSessionFactory
引入数据源 ref
指定MyBatis路径 configLocation 其value值为MyBaits文件路径
<!-- 配置Mybatis工厂:SqlSessionFactory -->
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="dataSource" ref="dataSource"></property>
<!-- 指定Mybatis核心配置文件位置 -->
<property name="configLocation" value="classpath:mybatis-config.xml"></property>
</bean>
- 配置mapper扫描器: 来扫描映射文件 接口,调用其方法
通过spring来扫描mapper接口
放置mapper属性位置 value值为对应路径 具体到mapper包名
<!-- 配置mapper扫描器 -->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<property name="basePackage" value="bzu.qst.dao"></property>
</bean>
- 指定扫描的包(服务层的包 service),使注解生效
<!-- 扫描Service -->
<context:component-scan base-package="bzu.qst.service"></context:component-scan>
- MyBatista配置文件
搜索xml 创建mybatis-config.xml文件 选择最后一个选项
根据项目中使用Mybatis的jar包版本 所以要找相应版本的Mybatis用户手册
链接信息已经在applicationContext中配置好了,所以只需要引入映射文件就可以了 - 引入映射文件 实用类路径引入
将 . 改成 /
有几个映射文件引入几个mappe
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
<!-- 有几个映射文件写几个mapper -->
<mappers>
<mapper resource="bzu/qst/mapper/AdminMapper.xml"/>
</mappers>
</configuration>
-
Log4j
Log4j可以直接复制过来 用来在控制台上输出相应信息 -
SpringMVC配置文件
生成.xml文件 -
扫描控制器层所在的包controller 找到对应的包Context
<!-- controller路径 使用SpringMVC认为包下用了@controller注解的类是控制器-->
<context:component-scan base-package="bzu.qst.controller"/>
- 配置视图解析器 显示用户所要显示的内容将路径连接起来
配置视图的前缀和后缀 返回的视图名加上前缀和后缀 所以返回时只需要写出jsp页面的名字就可以了
prefix WEB-INF/jsp
suffix .jsp
<!-- 视图解析器 -->
<bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix">
<!-- jsp页面位置++根目录 -->
<value>/WEB-INF/jsp/</value>
</property>
<property name="suffix">
<value>.jsp</value>
</property>
</bean>
3.静态
<!-- 支持mvc注解驱动 -->
<mvc:annotation-driven/>
<!-- Spring MVC不处理静态资源 -->
<mvc:default-servlet-handler/>
- web.xml配置文件
将web-app改成大的结束标签
- 配置spring相关的 加载spring,实例化applicationContext容器
<!-- Spring加载 -->
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:applicationContext.xml</param-value>
</context-param>
- 以ContextLoaderListener的方式来启动Spring容器
<!-- 以ContextLoaderListener方式来启动容器 -->
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
- 前端控制器
Servlet 类是固定写法
在url-pattern中写可以处理的请求
配置初始化参数 固定写法 SpringMVC-config.xml 的路径
web.xml
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" id="WebApp_ID" version="3.0">
<!-- Spring加载 -->
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:applicationContext.xml</param-value>
</context-param>
<!-- 以ContextLoaderListener方式来启动容器 -->
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<!-- 编码过滤器 -->
<filter>
<filter-name>encoding</filter-name>
<filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
<init-param>
<param-name>encoding</param-name>
<param-value>UTF-8</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>encoding</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
<!-- Spring mvc加载 -->
<servlet>
<servlet-name>springmvc</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<!-- 初始化参数 -->
<param-name>contextConfigLocation</param-name>
<param-value>classpath:springmvc-config.xml</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>springmvc</servlet-name>
<!-- 可以处理的请求 -->
<url-pattern>/</url-pattern>
</servlet-mapping>
</web-app>