SSM框架学习(六)——SSM整合
一.Maven
Maven提供了仓库的概念,让这些依赖放进仓库中,并且maven还会将和该jar包有相关依赖的jar包也都导入项目。
Maven安装配置请参考:Maven详解(二)------ Maven的安装配置
pom.xml文件描述了maven项目的基本信息,一个最简单的pom.xml文件至少需要包含四个元素:modelVersion, groupId, artiffactId 和 version。
- project:所有元素的根元素,该元素声明的信息主要为了方便第三方插件使用。
- modelVersion:用于指定当前POM模型的版本,对于maven2,maven3只能是4.0.0。
- groupId:用于指定当前项目所属的团体,公司,小组,组织 或 其它团体.
- artiffactId:当前项目所属组的唯一的ID号,
- version:用于指定当前项目的版本编号。比如:0.0.1-SNAPSHOT。后面的SNAPSHOT常指正在开发中的项目
- Packaging:项目的打包类型:pom、jar、war
packing默认是jar类型,
pom ---------> 父类型都为pom类型
jar ---------> 内部调用或者是作服务使用
war ---------> 需要部署的项目
二.SSM框架整合
- 使用Maven创建Web项目:新手在IDEA如何创建一个Web项目
- 在pom.xml中添加jar包
<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> cn.goktech</groupId>
<artifactId>JavaWeb</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>war</packaging>
<properties>
<spring.version>5.1.3.RELEASE</spring.version>
</properties>
<!-- 引用jar包 -->
<dependencies>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-core</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-beans</artifactId>
<version>5.1.3.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>5.1.3.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context-support</artifactId>
<version>5.1.3.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-tx</artifactId>
<version>5.1.3.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-orm</artifactId>
<version>5.1.3.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-aop</artifactId>
<version>5.1.3.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-web</artifactId>
<version>5.1.3.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>5.1.3.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-jdbc</artifactId>
<version>5.1.3.RELEASE</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.47</version>
</dependency>
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.4.0</version>
</dependency>
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis-spring</artifactId>
<version>1.3.1</version>
</dependency>
<dependency>
<groupId>commons-io</groupId>
<artifactId>commons-io</artifactId>
<version>2.2</version>
</dependency>
<dependency>
<groupId>commons-fileupload</groupId>
<artifactId>commons-fileupload</artifactId>
<version>1.3.2</version>
</dependency>
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-dbcp2</artifactId>
<version>2.6.0</version>
</dependency>
<dependency>
<groupId>com.mchange</groupId>
<artifactId>c3p0</artifactId>
<version>0.9.5.2</version>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>jstl</artifactId>
<version>1.1.2</version>
</dependency>
<dependency>
<groupId>taglibs</groupId>
<artifactId>standard</artifactId>
<version>1.1.0</version>
</dependency>
</dependencies>
</project>
- 数据库参数配置文件:jdbc.propertis
driver=com.mysql.jdbc.Driver
url=jdbc:mysql://localhost:3306/数据库名
username=root
password=123456
- 创建Mybatis的配置文件——springMybatis.xml
<!DOCTYPE configuration
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
<!--打印sql语句到控制台-->
<settings>
<setting name="logImpl" value="STDOUT_LOGGING" />
</settings>
</configuration>
- 创建SpringMVC的配置文件——springmvc.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:util="http://www.springframework.org/schema/util"
xmlns:mvc="http://www.springframework.org/schema/mvc"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-4.3.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-4.3.xsd
http://www.springframework.org/schema/util
http://www.springframework.org/schema/util/spring-util-4.3.xsd
http://www.springframework.org/schema/mvc
http://www.springframework.org/schema/mvc/spring-mvc-4.3.xsd
">
<!-- 扫描注解配置 -->
<context:component-scan base-package="cn.goktech" />
<!-- 扫描requestMapping注解 -->
<mvc:annotation-driven />
<!-- 配置资源映射 不拦截静态资源 js css -->
<mvc:resources location="/" mapping="/**/*.*"></mvc:resources>
<!-- 配置视图解析器 -->
<bean
class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/jsp/" />
<property name="suffix" value=".jsp" />
</bean>
<!-- 配置拦截器 -->
<mvc:interceptors>
<mvc:interceptor>
<mvc:mapping path="/**" /><!-- 拦截所有请求 -->
<mvc:exclude-mapping path="/yongh/login"/><!-- 设置允许通过的请求 -->
<bean class="cn.goktech.intercept.CheckLogin"/>
</mvc:interceptor>
</mvc:interceptors>
</beans>
- 创建Spring的配置文件——applicationContext.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:util="http://www.springframework.org/schema/util"
xmlns:mvc="http://www.springframework.org/schema/mvc"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-4.3.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-4.3.xsd
http://www.springframework.org/schema/util
http://www.springframework.org/schema/util/spring-util-4.3.xsd
http://www.springframework.org/schema/mvc
http://www.springframework.org/schema/mvc/spring-mvc-4.3.xsd
">
<!-- 加载连接数据库配置文件 -->
<util:properties id="ds" location="classpath:jdbc.properties" />
<!-- 配置数据源 -->
<bean id="dataSource"
class="org.apache.commons.dbcp2.BasicDataSource">
<property name="driverClassName" value="#{ds.driver}" />
<property name="url" value="#{ds.url}" />
<property name="username" value="#{ds.username}" />
<property name="password" value="#{ds.password}" />
</bean>
<!-- 配置sqlSessionFactory -->
<bean id="sqlSessionFactory"
class="org.mybatis.spring.SqlSessionFactoryBean">
<!-- 属性configLocation 表示mybatis的核心配置文件的位置 -->
<property name="configLocation" value="classpath:springMybatis.xml" />
<property name="dataSource" ref="dataSource" />
<!-- 自动扫描mapper.xml配置文件 -->
<property name="mapperLocations" value="classpath:mapper/*.xml" />
<!-- 给包起别名 -->
<!-- <property name="typeAliasesPackage" value="cn.goktech.pojo" /> -->
</bean>
<!-- 扫描DAO接口 -->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<property name="basePackage" value="cn.goktech.dao" />
</bean>
<!-- 业务层对象和dao层对象都是spring管理 -->
<context:component-scan base-package="cn.goktech.service" />
</beans>
三.Myabtis逆向工程
在实际开发过程中涉及到表的数目可能会比较多此时为每张表去书写实体类和sql语句是不合适,尤其是很多代码都是重复性的,没有什么技术可言,因此在mybatis官方提供了逆向工程,可以针对单表自动生成mybatis执行所需要的代码(包括mapper.xml,mapper.java,pojo)需要使用到的逆向工程jar包:mybatis-generator-core-1.3.2.jar
- 在pom.xml中添加jar包
<dependency>
<groupId>org.mybatis.generator</groupId>
<artifactId>mybatis-generator-maven-plugin</artifactId>
<version>1.3.6</version>
</dependency>
- 配置generatorConfig.xml
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE generatorConfiguration
PUBLIC "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN"
"http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd">
<generatorConfiguration>
<context id="testTables" targetRuntime="MyBatis3">
<commentGenerator>
<!-- 是否去除自动生成的注释 true:是 : false:否 -->
<property name="suppressAllComments" value="true"/>
</commentGenerator>
<!--【需要改】数据库连接的信息:驱动类、连接地址、用户名、密码 -->
<!-- <jdbcConnection driverClass="com.mysql.jdbc.Driver" connectionURL="jdbc:mysql://localhost:3306/test"
userId="root" password="mysql"> </jdbcConnection> -->
<jdbcConnection driverClass="oracle.jdbc.driver.OracleDriver"
connectionURL="jdbc:oracle:thin:@127.0.0.1:1521:orcl" userId="DzBank07"
password="123">
</jdbcConnection>
<!-- 默认false,把JDBC DECIMAL 和 NUMERIC 类型解析为 Integer,为 true时把JDBC DECIMAL
和 NUMERIC 类型解析为java.math.BigDecimal -->
<javaTypeResolver>
<property name="forceBigDecimals" value="false"/>
</javaTypeResolver>
<!-- 【需要改】targetProject:生成PO类的位置 -->
<javaModelGenerator targetPackage="cn.goktech.pojo"
targetProject=".\src\main\java">
<!-- enableSubPackages:是否让schema作为包的后缀 -->
<property name="enableSubPackages" value="false"/>
<!-- 从数据库返回的值被清理前后的空格 -->
<property name="trimStrings" value="true"/>
</javaModelGenerator>
<!-- 【需要改】targetProject:mapper映射文件(接口和xml生成的位置)生成的位置 -->
<sqlMapGenerator targetPackage="mapper"
targetProject=".\src\main\resources">
<!-- enableSubPackages:是否让schema作为包的后缀 -->
<property name="enableSubPackages" value="false"/>
</sqlMapGenerator>
<!-- 【需要改】targetPackage:mapper接口生成的位置 -->
<javaClientGenerator type="XMLMAPPER"
targetPackage="cn.goktech.dao" targetProject=".\src\main\java">
<!-- enableSubPackages:是否让schema作为包的后缀 -->
<property name="enableSubPackages" value="false"/>
</javaClientGenerator>
<!-- 【需要改】指定数据库表 -->
<table schema="DzBank07" tableName="Yongh"></table>
<table schema="DzBank07" tableName="Quanx"></table>
<table schema="DzBank07" tableName="Caid"></table>
<table schema="DzBank07" tableName="Quanxgl"></table>
<table schema="DzBank07" tableName="Riz"></table>
<table schema="DzBank07" tableName="Dazyhkh"></table>
<table schema="DzBank07" tableName="HEXINDATAREPOSITORY"></table>
<table schema="DzBank07" tableName="Jig"></table>
</context>
</generatorConfiguration>
- 自动生成所mapper.xml,entity和dao
public class GeneratorConfig {
public void generator() throws Exception {
List<String> warnings = new ArrayList<String>();
boolean overwrite = true;
// 指定 逆向工程配置文件
File configFile = new File("src/main/resources/generatorConfig.xml");
ConfigurationParser cp = new ConfigurationParser(warnings);
Configuration config = cp.parseConfiguration(configFile);
DefaultShellCallback callback = new DefaultShellCallback(overwrite);
MyBatisGenerator myBatisGenerator = new MyBatisGenerator(config, callback, warnings);
myBatisGenerator.generate(null);
// 建议大家使用带有selecttive
}
public static void main(String[] args) throws Exception {
try {
GeneratorConfig generatorSqlmap = new GeneratorConfig();
generatorSqlmap.generator();
System.out.println("生成结束");
} catch (Exception e) {
e.printStackTrace();
}
}
}
四.分页插件
- 在pom.xml文件中添加jar包
<dependency>
<groupId>com.github.pagehelper</groupId>
<artifactId>pagehelper</artifactId>
<version>4.0.0</version>
</dependency>
- 在springMybatis.xml中添加分页插件配置
<plugins>
<plugin interceptor="com.github.pagehelper.PageHelper">
<!-- 设置数据库类型 oracle,Mysql,MariaDB,SQLite,Hsqldb,PostgreSQL六种数据库 -->
<property name="dialect" value="oracle" />
</plugin>
</plugins>
五.项目实战
放上我的一个半成品项目:github下载
项目已完成内容包括:
- 菜单管理
- 未登录拦截过滤
- 日志写入
- echarts图表展示
- 分页显示查询
- json从前端到后端和从后端到前端的交互
- ajax传输数据
- 权限管理
- 不同用户登录显示不同菜单
- 数据的增删改查
需要数据库的私我,有些数据不能上传到网上。