SSM框架整合
Posted java123456
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SSM框架整合相关的知识,希望对你有一定的参考价值。
项目描述:本项目是基本的ssm整合,基本的增删改查,仅供学习和参考!
Spring + SpringMVC + Mybatis + Freemarker
1、项目目录
2、系统介绍
系统代码规范参考《阿里巴巴Java开发手册终极版v1.3.0》
系统架构:Spring + SpringMVC + MyBatis
前端模板引擎:freemarker
数据源连接池:Druid
日志框架:log4j
测试框架:Junit4
项目管理:maven
数据库:mysql5.6
jdk版本:jdk1.8
开发服务器:Tomcat 8.0
功能:增删改查
系统结构介绍:
系统实现路径:src/main/java
系统测试路径:src/main/test
静态资源及配置文件路径:src/main/resources
包名:
com.elanbase.hr.common
com.elanbase.hr.config
com.elanbase.hr.controller
com.elanbase.hr.mapper
com.elanbase.hr.model
com.elanbase.hr.service
com.elanbase.hr.service.impl
html页面路径:webapp
freemarker模板路径:webapp/WEB-INF/ftl
3、配置文件
3.1 Maven配置
1 <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 2 xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> 3 <modelVersion>4.0.0</modelVersion> 4 <groupId>com.elanbasehr</groupId> 5 <artifactId>elanbasehr</artifactId> 6 <version>0.0.1-SNAPSHOT</version> 7 <packaging>war</packaging> 8 <name>elanbasehr</name> 9 10 <properties> 11 <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> 12 <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding> 13 <java.version>1.8</java.version> 14 <junit.version>4.9</junit.version> 15 <spring.version>4.3.10.RELEASE</spring.version> 16 <mybatis.version>3.4.4</mybatis.version> 17 <mybatis.spring.version>1.3.1</mybatis.spring.version> 18 <jstl.version>1.2</jstl.version> 19 <log4j.version>1.2.17</log4j.version> 20 <fastjson.version>1.2.35</fastjson.version> 21 <slf4j.version>1.7.25</slf4j.version> 22 <jackson.version>1.9.13</jackson.version> 23 <commons-fileupload.version>1.3.3</commons-fileupload.version> 24 <commons-io.version>2.5</commons-io.version> 25 <commons-codec.version>1.10</commons-codec.version> 26 <commons-dbcp.version>1.4</commons-dbcp.version> 27 </properties> 28 29 <dependencies> 30 <!-- https://mvnrepository.com/artifact/com.alibaba/druid --> 31 <dependency> 32 <groupId>com.alibaba</groupId> 33 <artifactId>druid</artifactId> 34 <version>1.1.8</version> 35 </dependency> 36 <!-- https://mvnrepository.com/artifact/org.springframework.boot/spring-boot-starter-web --> 37 <dependency> 38 <groupId>org.springframework.boot</groupId> 39 <artifactId>spring-boot-starter-web</artifactId> 40 <version>1.5.12.RELEASE</version> 41 </dependency> 42 43 <dependency> 44 <groupId>org.springframework.boot</groupId> 45 <artifactId>spring-boot-configuration-processor</artifactId> 46 <version>2.0.1.RELEASE</version> 47 </dependency> 48 49 <!-- freeMarker --> 50 <dependency> 51 <groupId>org.freemarker</groupId> 52 <artifactId>freemarker</artifactId> 53 <version>2.3.23</version> 54 </dependency> 55 56 <!-- Junit测试 --> 57 <dependency> 58 <groupId>junit</groupId> 59 <artifactId>junit</artifactId> 60 <version>${junit.version}</version> 61 <scope>test</scope> 62 </dependency> 63 64 <!-- spring包 core、web、oxm、tx、jdbc、webmvc、aop、context、test --> 65 <dependency> 66 <groupId>org.springframework</groupId> 67 <artifactId>spring-core</artifactId> 68 <version>${spring.version}</version> 69 </dependency> 70 <dependency> 71 <groupId>org.springframework</groupId> 72 <artifactId>spring-web</artifactId> 73 <version>${spring.version}</version> 74 </dependency> 75 <dependency> 76 <groupId>org.springframework</groupId> 77 <artifactId>spring-oxm</artifactId> 78 <version>${spring.version}</version> 79 </dependency> 80 <dependency> 81 <groupId>org.springframework</groupId> 82 <artifactId>spring-tx</artifactId> 83 <version>${spring.version}</version> 84 </dependency> 85 <dependency> 86 <groupId>org.springframework</groupId> 87 <artifactId>spring-jdbc</artifactId> 88 <version>${spring.version}</version> 89 </dependency> 90 <dependency> 91 <groupId>org.springframework</groupId> 92 <artifactId>spring-webmvc</artifactId> 93 <version>${spring.version}</version> 94 </dependency> 95 <dependency> 96 <groupId>org.springframework</groupId> 97 <artifactId>spring-aop</artifactId> 98 <version>${spring.version}</version> 99 </dependency> 100 101 <dependency> 102 <groupId>org.springframework</groupId> 103 <artifactId>spring-context-support</artifactId> 104 <version>${spring.version}</version> 105 </dependency> 106 <dependency> 107 <groupId>org.springframework</groupId> 108 <artifactId>spring-test</artifactId> 109 <version>${spring.version}</version> 110 </dependency> 111 <!-- mybatis核心包 --> 112 <dependency> 113 <groupId>org.mybatis</groupId> 114 <artifactId>mybatis</artifactId> 115 <version>${mybatis.version}</version> 116 </dependency> 117 <!-- mybatis/spring包 --> 118 <dependency> 119 <groupId>org.mybatis</groupId> 120 <artifactId>mybatis-spring</artifactId> 121 <version>${mybatis.spring.version}</version> 122 </dependency> 123 124 <!-- 导入Mysql数据库链接jar包 --> 125 <dependency> 126 <groupId>mysql</groupId> 127 <artifactId>mysql-connector-java</artifactId> 128 <version>5.1.38</version> 129 </dependency> 130 131 <!-- 导入dbcp的jar包,用来在applicationContext.xml中配置数据库 --> 132 <dependency> 133 <groupId>commons-dbcp</groupId> 134 <artifactId>commons-dbcp</artifactId> 135 <version>${commons-dbcp.version}</version> 136 </dependency> 137 <!-- JSTL标签类 --> 138 <dependency> 139 <groupId>jstl</groupId> 140 <artifactId>jstl</artifactId> 141 <version>${jstl.version}</version> 142 </dependency> 143 <!-- 日志文件管理包 --> 144 <dependency> 145 <groupId>log4j</groupId> 146 <artifactId>log4j</artifactId> 147 <version>${log4j.version}</version> 148 </dependency> 149 150 <!-- 格式化对象,方便输出日志 --> 151 <dependency> 152 <groupId>com.alibaba</groupId> 153 <artifactId>fastjson</artifactId> 154 <version>${fastjson.version}</version> 155 </dependency> 156 157 <dependency> 158 <groupId>org.slf4j</groupId> 159 <artifactId>slf4j-api</artifactId> 160 <version>${slf4j.version}</version> 161 </dependency> 162 163 <dependency> 164 <groupId>org.slf4j</groupId> 165 <artifactId>slf4j-log4j12</artifactId> 166 <version>${slf4j.version}</version> 167 </dependency> 168 <!-- json和bean之间相互转换 --> 169 <dependency> 170 <groupId>org.codehaus.jackson</groupId> 171 <artifactId>jackson-core-asl</artifactId> 172 <version>${jackson.version}</version> 173 </dependency> 174 <dependency> 175 <groupId>org.codehaus.jackson</groupId> 176 <artifactId>jackson-mapper-asl</artifactId> 177 <version>${jackson.version}</version> 178 </dependency> 179 <!-- 上传组件包 --> 180 <dependency> 181 <groupId>commons-fileupload</groupId> 182 <artifactId>commons-fileupload</artifactId> 183 <version>${commons-fileupload.version}</version> 184 </dependency> 185 <dependency> 186 <groupId>commons-io</groupId> 187 <artifactId>commons-io</artifactId> 188 <version>${commons-io.version}</version> 189 </dependency> 190 <dependency> 191 <groupId>commons-codec</groupId> 192 <artifactId>commons-codec</artifactId> 193 <version>${commons-codec.version}</version> 194 </dependency> 195 196 <dependency> 197 <groupId>javax.servlet</groupId> 198 <artifactId>javax.servlet-api</artifactId> 199 <version>4.0.0-b07</version> 200 <scope>provided</scope> 201 </dependency> 202 </dependencies> 203 204 <build> 205 <testSourceDirectory>src/main/test</testSourceDirectory> 206 <resources> 207 <resource> 208 <directory>src/main/java</directory> 209 <excludes> 210 <exclude>**/*.java</exclude> 211 </excludes> 212 </resource> 213 <resource> 214 <directory>src/main/resources</directory> 215 <excludes> 216 <exclude>**/*.java</exclude> 217 </excludes> 218 </resource> 219 </resources> 220 <plugins> 221 <plugin> 222 <artifactId>maven-compiler-plugin</artifactId> 223 <version>3.5.1</version> 224 <configuration> 225 <source>1.8</source> 226 <target>1.8</target> 227 </configuration> 228 </plugin> 229 <plugin> 230 <artifactId>maven-war-plugin</artifactId> 231 <version>3.0.0</version> 232 <configuration> 233 <warSourceDirectory>webapp</warSourceDirectory> 234 </configuration> 235 </plugin> 236 </plugins> 237 </build> 238 </project>
3.2 Mybatis配置(可选):mybatis-config.xml
1 <?xml version="1.0" encoding="UTF-8" ?> 2 <!DOCTYPE configuration 3 PUBLIC "-//mybatis.org//DTD Config 3.0//EN" 4 "http://mybatis.org/dtd/mybatis-3-config.dtd"> 5 <configuration> 6 7 <settings> 8 <!--设置启用数据库字段下划线映射到java对象的驼峰式命名属性,默认为false --> 9 <setting name="mapUnderscoreToCamelCase" value="true" /> 10 </settings> 11 12 <!-- mybatis别名定义 --> 13 <!-- <typeAliases> 14 <typeAlias type="com.elanbase.hr.model.SysUser" alias="SysUser" /> 15 </typeAliases> --> 16 17 </configuration>
3.3 Spring集成Mybatis配置:spring-mybatis.xml
1 <?xml version="1.0" encoding="UTF-8"?> 2 <beans xmlns="http://www.springframework.org/schema/beans" 3 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:p="http://www.springframework.org/schema/p" 4 xmlns:context="http://www.springframework.org/schema/context" xmlns:tx="http://www.springframework.org/schema/tx" 5 xsi:schemaLocation=" 6 http://www.springframework.org/schema/beans 7 http://www.springframework.org/schema/beans/spring-beans.xsd 8 http://www.springframework.org/schema/context 9 http://www.springframework.org/schema/context/spring-context.xsd 10 http://www.springframework.org/schema/tx 11 http://www.springframework.org/schema/tx/spring-tx.xsd"> 12 13 <!-- 自动扫描 --> 14 <context:component-scan base-package="com.elanbase.hr.service" /> 15 16 <!-- 阿里 druid数据库连接池 --> 17 <bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource" destroy-method="close"> 18 <!-- 数据库基本信息配置 --> 19 <property name="driverClassName" value="com.mysql.jdbc.Driver" /> 20 <property name="url" value="jdbc:mysql://localhost:3306/elanbasehr?characterEncoding=utf-8" /> 21 <property name="username" value="root" /> 22 <property name="password" value="root" /> 23 <property name="filters" value="stat" /> 24 <!-- 最大并发连接数 --> 25 <property name="maxActive" value="20" /> 26 <!-- 初始化连接数量 --> 27 <property name="initialSize" value="1" /> 28 <!-- 配置获取连接等待超时的时间 --> 29 <property name="maxWait" value="60000" /> 30 <!-- 最小空闲连接数 --> 31 <property name="minIdle" value="10" /> 32 <!-- 最大空闲连接数 --> 33 <property name="maxIdle" value="15" /> 34 <!-- 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒 --> 35 <property name="timeBetweenEvictionRunsMillis" value="60000" /> 36 <!-- 配置一个连接在池中最小生存的时间,单位是毫秒 --> 37 <property name="minEvictableIdleTimeMillis" value="300000" /> 38 <property name="validationQuery" value="SELECT" /> 39 <property name="testWhileIdle" value="true" /> 40 <property name="testOnBorrow" value="false" /> 41 <property name="testOnReturn" value="false" /> 42 <property name="maxOpenPreparedStatements" value="20" /> 43 <!-- 打开removeAbandoned功能 --> 44 <property name="removeAbandoned" value="true" /> 45 <!-- 1800秒,也就是30分钟 --> 46 <property name="removeAbandonedTimeout" value="1800" /> 47 <!-- 关闭abanded连接时输出错误日志 --> 48 <property name="logAbandoned" value="true" /> 49 </bean> 50 51 <!-- spring和MyBatis完美整合,不需要mybatis的配置映射文件 --> 52 <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"> 53 <property name="dataSource" ref="dataSource" /> 54 <property name="configLocation" value="classpath:mybatis-config.xml" /> 55 <!-- 自动扫描mapping.xml文件 --> 56 <property name="mapperLocations" value="classpath:com/elanbase/hr/mapper/*.xml"></property> 57 </bean> 58 59 <!-- DAO接口所在包名,Spring会自动查找其下的类 --> 60 <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer"> 61 <property name="sqlSessionFactory" ref="sqlSessionFactory" /> 62 <property name="basePackage" value="com.elanbase.hr.mapper" /> 63 </bean> 64 65 <!-- 事务管理 --> 66 <bean id="txManager" 67 class="org.springframework.jdbc.datasource.DataSourceTransactionManager"> 68 <property name="dataSource" ref="dataSource" /> 69 </bean> 70 71 <!-- 配置事务通知属性 --> 72 <tx:advice id="txAdvice" transaction-manager="txManager"> 73 <!-- 定义事务传播属性 --> 74 <tx:attributes> 75 <tx:method name="insert*" propagation="REQUIRED" /> 76 <tx:method name="update*" propagation="REQUIRED" /> 77 <tx:method name="edit*" propagation="REQUIRED" /> 78 <tx:method name="save*" propagation="REQUIRED" /> 79 <tx:method name="add*" propagation="REQUIRED" /> 80 <tx:method name="new*" propagation="REQUIRED" /> 81 <tx:method name="set*" propagation="REQUIRED" /> 82 <tx:method name="remove*" propagation="REQUIRED" /> 83 <tx:method name="delete*" propagation="REQUIRED" /> 84 <tx:method name="change*" propagation="REQUIRED" /> 85 <tx:method name="get*" propagation="REQUIRED" read-only="true" /> 86 <tx:method name="find*" propagation="REQUIRED" read-only="true" /> 87 <tx:method name="select*" propagation="REQUIRED" read-only="true" /> 88 <tx:method name="load*" propagation="REQUIRED" read-only="true" /> 89 <tx:method name="*" propagation="REQUIRED" read-only="true" /> 90 </tx:attributes> 91 </tx:advice> 92 93 94 <!-- 配置事务切面 --> 95 <!-- <aop:config> <aop:pointcut id="serviceOperation" expression="execution(* 96 com.ssm.service.*.*(..))" /> <aop:advisor advice-ref="txAdvice" pointcut-ref="serviceOperation" 97 /> </aop:config> --> 98 99 </beans>
3.4 Spring集成SpringMVC配置:spring-mvc.xml
1 <?xml version="1.0" encoding="UTF-8"?> 2 <beans xmlns="http://www.springframework.org/schema/beans" 3 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context" 4 xmlns:mvc="http://www.springframework.org/schema/mvc" 5 xsi:schemaLocation="http://www.springframework.org/schema/beans 6 http://www.springframework.org/schema/beans/spring-beans.xsd 7 http://www.springframework.org/schema/context 8 http://www.springframework.org/schema/context/spring-context-4.0.xsd 9 http://www.springframework.org/schema/mvc 10 http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd"> 11 12 <!-- 对包中的所有类进行扫描,以完成Bean创建和自动依赖注入的功能 --> 13 <context:component-scan base-package="com.elanbase.hr.controller" /> 14 15 <!-- 开启注解 --> 16 <mvc:annotation-driven /> 17 18 <!-- 配置静态资源,直接映射到对应的文件夹,不被DispatcherServlet处理,3.04新增功能,需要重新设置spring-mvc-3.0.xsd --> 19 <mvc:resources mapping="/img/**" location="/img/" /> 20 <mvc:resources mapping="/images/**" location="/images/" /> 21 <mvc:resources mapping="/js/**" location="/js/" /> 22 <mvc:resources mapping="/css/**" location="/css/" /> 23 <mvc:resources mapping="/fonts/**" location="/fonts/" /> 24 25 <!-- 配置freeMarker视图解析器 --> 26 <bean id="viewResolverFtl" 27 class="org.springframework.web.servlet.view.freemarker.FreeMarkerViewResolver"> 28 <property name="viewClass" 29 value="org.springframework.web.servlet.view.freemarker.FreeMarkerView" /> 30 <property name="contentType" value="text/html; charset=utf-8" /> 31 <property name="cache" value="true" /> 32 <property name="suffix" value=".html" /> 33 <property name="order" value="0" /> 34 </bean> 35 36 <!-- 配置freeMarker的模板路径 --> 37 <bean id="freemarkerConfig" class="org.springframework.web.servlet.view.freemarker.FreeMarkerConfigurer"> 38 <property name="templateLoaderPath" value="" /> 39 </bean> 40 41 </beans>
3.5 日志配置:log4j.xml
1 <?xml version="1.0" encoding="UTF-8" ?> 2 <!DOCTYPE log4j:configuration SYSTEM "log4j.dtd"> 3 <log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/"> 4 <appender name="STDOUT" class="org.apache.log4j.ConsoleAppender"> 5 <layout class="org.apache.log4j.PatternLayout"> 6 <param name="ConversionPattern" value="%-5p %d{MM-dd HH:mm:ss,SSS} %m (%F:%L) \\n" /> 7 </layout> 8 </appender> 9 10 <logger name="java.sql"> 11 <level value="ERROR" /> 12 </logger> 13 14 <logger name="org.apache.ibatis"> 15 <level value="ERROR" /> 16 </logger> 17 18 <root> 19 <level value="WARN" /> 20 <appender-ref ref="STDOUT" /> 21 </root> 22 23 </log4j:configuration>
3.6 web.xml 配置
1 <?xml version="1.0" encoding="UTF-8"?> 2 <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 3 xmlns="http://xmlns.jcp.org/xml/ns/javaee" 4 xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd" 5 id="WebApp_ID" version="3.1"> 6 <display-name>elanbasehr</display-name> 7 <welcome-file-list> 8 <welcome-file>index.html</welcome-file> 9 <welcome-file>index.jsp</welcome-file> 10 </welcome-file-list> 11 12 <!-- 加载Spring容器配置 --> 13 <listener> 14 <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class> 15 </listener> 16 17 <!-- 加载 Spring 配置文件 --> 18 <context-param> 19 <param-name>contextConfigLocation</param-name> 20 <param-value>classpath*:spring-mybatis.xml</param-value> 21 </context-param> 22 23 <!-- 加载 SpringMVC 配置文件 --> 24 <servlet> 25 <servlet-name>springMVC</servlet-name> 26 <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> 27 <init-param> 28 <param-name>contextConfigLocation</param-name> 29 <param-value>classpath*:spring-mvc.xml</param-value> 30 </init-param> 31 <load-on-startup>1</load-on-startup> 32 </servlet> 33 <servlet-mapping> 34 <servlet-name>springMVC</servlet-name> 35 <url-pattern>/</url-pattern> 36 </servlet-mapping> 37 <servlet-mapping> 38 <servlet-name>default</servlet-name> 39 <url-pattern>*.html</url-pattern> 40 <url-pattern>*.js</url-pattern> 41 <url-pattern>*.css</url-pattern> 42 </servlet-mapping> 43 44 <!-- 连接池 启用Web监控统计功能 start--> 45 <filter> 46 <filter-name>DruidWebStatFilter</filter-name> 47 <filter-class>com.alibaba.druid.support.http.WebStatFilter</filter-class> 48 <init-param> 49 <param-name>exclusions</param-name> <!-- 经常需要排除一些不必要的url --> 50 <param-value>*.js,*.gif,*.jpg,*.png,*.css,*.ico,/druid/*</param-value> 51 </init-param> 52 </filter> 53 <filter-mapping> 54 <filter-name>DruidWebStatFilter</filter-name> 55 <url-pattern>/*</url-pattern> 56 </filter-mapping> 57 <servlet> 58 <servlet-name>DruidStatView</servlet-name> 59 <!-- 这个StatViewServlet的用途包括:提供监控信息展示的html页面;提供监控信息的JSON API --> 60 <servlet-class>com.alibaba.druid.support.http.StatViewServlet</servlet-class> 61 </servlet> 62 <servlet-mapping> 63 <servlet-name>DruidStatView</servlet-name> 64 <url-pattern>/druid/*</url-pattern> 65 </servlet-mapping> 66 <!-- 连接池 启用Web监控统计功能 end--> 67 68 69 </web-app>
3.7 Mybatis Generator 基本配置(可选):mybatis-generator.xml
1 <?xml version="1.0" encoding="UTF-8"?> 2 <!DOCTYPE generatorConfiguration 3 PUBLIC "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN" 4 "http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd"> 5 <generatorConfiguration> 6 <context id="DB2Tables" targetRuntime="MyBatis3"> 7 <commentGenerator> 8 <property name="suppressDate" value="true" /> 9 <property name="suppressAllComments" value="true" /> 10 </commentGenerator> 11 12 <!--数据库链接地址账号密码 --> 13 <jdbcConnection driverClass="com.mysql.jdbc.Driver" 14 connectionURL="jdbc:mysql://localhost:3306/elanbasehr?characterEncoding=UTF-8" userId="root" password="root"> 15 </jdbcConnection> 16 <javaTypeResolver> 17 <property name="forceBigDecimals" value="false" /> 18 </javaTypeResolver> 19 20 <!--生成Model类存放位置 --> 21 <javaModelGenerator targetPackage="com.elanbase.hr.model" targetProject="elanbasehr"> 22 <property name="enableSubPackages" value="true" /> 23 <property name="trimStrings" value="true" /> 24 </javaModelGenerator> 25 <!--生成映射文件xml存放位置 --> 26 <sqlMapGenerator targetPackage="com.elanbase.hr.mapper" targetProject="elanbasehr"> 27 <property name="enableSubPackages" value="true" /> 28 </sqlMapGenerator> 29 <!--生成Dao类存放位置 --> 30 <javaClientGenerator type="MIXEDMAPPER" targetPackage="com.elanbase.hr.mapper" targetProject="elanbasehr"> 31 <property name="enableSubPackages" value="true" /> 32 </javaClientGenerator> 33 34 <!--生成对应表及类名 --> 35 <table tableName="sys_user" domainObjectName="SysUser" 36 enableCountByExample="false" enableUpdateByExample="false" 37 enableDeleteByExample="false" enableSelectByExample="false" 38 selectByExampleQueryId="false"> 39 </table> 40 41 </context> 42 </generatorConfiguration>
4、数据库:elanbasehr.sql
1 /* 2 Navicat MySQL Data Transfer 3 4 Source Server : localhost 5 Source Server Version : 50717 6 Source Host : localhost:3306 7 Source Database : elanbasehr 8 9 Target Server Type : MYSQL 10 Target Server Version : 50717 11 File Encoding : 65001 12 13 Date: 2018-04-24 11:50:06 14 */ 15 16 SET FOREIGN_KEY_CHECKS=0; 17 18 -- ---------------------------- 19 -- Table structure for sys_user 20 -- ---------------------------- 21 DROP TABLE IF EXISTS `sys_user`; 22 CREATE TABLE `sys_user` ( 23 `id` bigint(19) NOT NULL AUTO_INCREMENT COMMENT ‘主键id‘, 24 `login_name` varchar(64) NOT NULL COMMENT ‘登录名‘, 25 `name` varchar(64) NOT NULL COMMENT ‘用户名‘, 26 `password` varchar(64) NOT NULL COMMENT ‘密码‘, 27 `sex` tinyint(2) DEFAULT ‘0‘ COMMENT ‘性别‘, 28 `age` tinyint(2) DEFAULT ‘0‘ COMMENT ‘年龄‘, 29 `phone` varchar(20) DEFAULT NULL COMMENT ‘手机号‘, 30 `user_type` tinyint(2) DEFAULT ‘0‘ COMMENT ‘用户类别‘, 31 `status` tinyint(2) DEFAULT ‘0‘ COMMENT ‘用户状态‘, 32 `del_flag` tinyint(1) DEFAULT NULL COMMENT ‘删除标记‘, 33 `update_time` datetime DEFAULT NULL COMMENT ‘更新时间‘, 34 `create_time` datetime DEFAULT NULL COMMENT ‘创建时间‘, 35 PRIMARY KEY (`id`) 36 ) ENGINE=InnoDB AUTO_INCREMENT=43 DEFAULT CHARSET=utf8 COMMENT=‘用户‘; 37 38 -- ---------------------------- 39 -- Records of sys_user 40 -- ---------------------------- 41 INSERT INTO `sys_user` VALUES (‘38‘, ‘admin‘, ‘系统管理员‘, ‘123456‘, ‘0‘, null, ‘‘, ‘0‘, ‘0‘, ‘0‘, ‘2018-04-24 10:52:59‘, ‘2018-04-24 10:52:59‘); 42 INSERT INTO `sys_user` VALUES (‘42‘, ‘test‘, ‘测试‘, ‘123456‘, ‘0‘, null, ‘‘, ‘0‘, ‘0‘, ‘0‘, ‘2018-04-24 21:46:39‘, ‘2018-04-24 21:34:54‘);
5、代码实现
com.elanbase.hr.model 实体类包
SysUser.java
1 package com.elanbase.hr.model; 2 3 import java.util.Date; 4 5 public class SysUser { 6 7 private Integer id; 8 9 private String loginName; 10 11 private String name; 12 13 private String password; 14 15 private Integer sex; 16 17 private Integer age; 18 19 private String phone; 20 21 private Integer userType; 22 23 private Integer status; 24 25 private Integer delFlag; 26 27 private Date updateTime; 28 29 private Date createTime; 30 31 public Integer getId() { 32 return id; 33 } 34 35 public void setId(Integer id) { 36 this.id = id; 37 } 38 39 public String getLoginName() { 40 return loginName; 41 } 42 43 public void setLoginName(String loginName) { 44 this.loginName = loginName == null ? null : loginName.trim(); 45 } 46 47 public String getName() { 48 return name; 49 } 50 51 public void setName(String name) { 52 this.name = name == null ? null : name.trim(); 53 } 54 55 public String getPassword() { 56 return password; 57 } 58 59 public void setPassword(String password) { 60 this.password = password == null ? null : password.trim(); 61 } 62 63 public Integer getSex() { 64 return sex; 65 } 66 67 public void setSex(Integer sex) { 68 this.sex = sex; 69 } 70 71 public Integer getAge() { 72 return age; 73 } 74 75 public void setAge(Integer age) { 76 this.age = age; 77 } 78 79 public String getPhone() { 80 return phone; 81 } 82 83 public void setPhone(String phone) { 84 this.phone = phone == null ? null : phone.trim(); 85 } 86 87 public Integer getUserType() { 88 return userType; 89 } 90 91 public void setUserType(Integer userType) { 92 this.userType = userType; 93 } 94 95 public Integer getStatus() { 96 return status; 97 } 98 99 public void setStatus(Integer status) { 100 this.status = status; 101 } 102 103 public Integer getDelFlag() { 104 return delFlag; 105 } 106 107 public void setDelFlag(Integer delFlag) { 108 this.delFlag = delFlag; 109 } 110 111 public Date getUpdateTime() { 112 return updateTime; 113 } 114 115 public void setUpdateTime(Date updateTime) { 116 this.updateTime = updateTime; 117 } 118 119 public Date getCreateTime() { 120 return createTime; 121 } 122 123 public void setCreateTime(Date createTime) { 124 this.createTime = createTime; 125 } 126 }
com.elanbase.hr.mapper 实体映射类 和 dao接口包
SysUserMapper.java
1 package com.elanbase.hr.mapper; 2 3 import java.util.List; 4 5 import com.elanbase.hr.model.SysUser; 6 7 public interface SysUserMapper { 8 9 SysUser getByPrimaryKey(Integer id); 10 11 List<SysUser> listSysUser(); 12 13 int insertSysUser(SysUser record); 14 15 int deleteByPrimaryKey(Integer id); 16 17 int updateByPrimaryKey(SysUser record); 18 19 }
SysUserMapper.xml
1 <?xml version="1.0" encoding="UTF-8"?> 2 <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> 3 <mapper namespace="com.elanbase.hr.mapper.SysUserMapper"> 4 <resultMap id="BaseResultMap" type="com.elanbase.hr.model.SysUser"> 5 <id column="id" jdbcType="INTEGER" property="id" /> 6 <result column="login_name" jdbcType="VARCHAR" property="loginName" /> 7 <result column="name" jdbcType="VARCHAR" property="name" /> 8 <result column="password" jdbcType="VARCHAR" property="password" /> 9 <result column="sex" jdbcType="INTEGER" property="sex" /> 10 <result column="age" jdbcType="INTEGER" property="age" /> 11 <result column="phone" jdbcType="VARCHAR" property="phone" /> 12 <result column="user_type" jdbcType="INTEGER" property="userType" /> 13 <result column="status" jdbcType="INTEGER" property="status" /> 14 <result column="del_flag" jdbcType="INTEGER" property="delFlag" /> 15 <result column="update_time" jdbcType="TIMESTAMP" property="updateTime" /> 16 <result column="create_time" jdbcType="TIMESTAMP" property="createTime" /> 17 </resultMap> 18 <sql id="Base_Column_List"> 19 id, login_name, name, password, sex, age, phone, user_type, 20 status, 21 del_flag, update_time, 22 create_time 23 </sql> 24 25 <select id="getByPrimaryKey" parameterType="Integer" resultType="com.elanbase.hr.model.SysUser"> 26 select * from sys_user where id = #{id} 27 </select> 28 29 <select id="listSysUser" resultType="com.elanbase.hr.model.SysUser"> 30 select * from sys_user 31 </select> 32 33 <insert id="insertSysUser" useGeneratedKeys="true" keyProperty="id" parameterType="com.elanbase.hr.model.SysUser"> 34 insert into sys_user (login_name,name,password) 35 values (#{loginName},#{name},#{password}) 36 </insert> 37 38 <delete id="deleteByPrimaryKey" parameterType="Integer"> 39 delete from sys_user where id = #{id} 40 </delete> 41 42 <update id="updateByPrimaryKey" parameterType="com.elanbase.hr.model.SysUser"> 43 update sys_user set login_name=#{loginName},name=#{name} where id = #{id} 44 </update> 45 46 </mapper>
com.elanbase.hr.service 业务接口包
SysUserService.java
1 package com.elanbase.hr.service; 2 3 import java.util.List; 4 5 import com.elanbase.hr.model.SysUser; 6 7 public interface SysUserService { 8 9 SysUser getByPrimaryKey(Integer id); 10 11 List<SysUser> listSysUser(); 12 13 int insertSysUser(SysUser record); 14 15 int deleteByPrimaryKey(Integer id); 16 17 int updateByPrimaryKey(SysUser record); 18 }
com.elanbase.hr.service.impl 业务实现类包
SysUserServiceImpl.java
1 package com.elanbase.hr.service.impl; 2 3 import java.util.List; 4 5 import javax.annotation.Resource; 6 7 import org.springframework.stereotype.Service; 8 9 import com.elanbase.hr.mapper.SysUserMapper; 10 import com.elanbase.hr.model.SysUser; 11 import com.elanbase.hr.service.SysUserService; 12 13 @Service 14 public class SysUserServiceImpl implements SysUserService { 15 16 @Resource 17 private SysUserMapper userMapper; 18 19 @Override 20 public SysUser getByPrimaryKey(Integer id) { 21 return userMapper.getByPrimaryKey(id); 22 } 23 24 @Override 25 public List<SysUser> listSysUser() { 26 return userMapper.listSysUser(); 27 } 28 29 @Override 30 public int insertSysUser(SysUser record) { 31 return userMapper.insertSysUser(record); 32 } 33 34 @Override 35 public int deleteByPrimaryKey(Integer id) { 36 return userMapper.deleteByPrimaryKey(id); 37 } 38 39 @Override 40 public int updateByPrimaryKey(SysUser record) { 41 return userMapper.updateByPrimaryKey(record); 42 } 43 44 }
com.elanbase.hr.controller 控制层包
SysUserController.java
1 package com.elanbase.hr.controller; 2 3 import java.util.List; 4 import javax.annotation.Resource; 5 import org.springframework.stereotype.Controller; 6 import org.springframework.ui.Model; 7 import org.springframework.web.bind.annotation.RequestMapping; 8 import org.springframework.web.bind.annotation.RequestMethod; 9 import org.springframework.web.bind.annotation.RequestParam; 10 import org.springframework.web.servlet.ModelAndView; 11 12 import com.elanbase.hr.model.SysUser; 13 import com.elanbase.hr.service.SysUserService; 14 15 @Controller 16 @RequestMapping(value = "user") 17 public class SysUserController { 18 19 @Resource 20 private SysUserService userService; 21 22 /** 23 * 获取用户对象 24 * 25 * @param mav 26 * @return 27 */ 28 @RequestMapping(value = "/get", method = RequestMethod.GET) 29 public ModelAndView getByPrimaryKey(ModelAndView mav) { 30 SysUser user = userService.getByPrimaryKey(38); 31 mav.addObject("user", user); 32 mav.setViewName("user"); 33 return mav; 34 } 35 36 /** 37 * 获取用户列表 38 * 39 * @param mav 40 * @return 41 */ 42 @RequestMapping(value = "/list", method = RequestMethod.GET) 43 public ModelAndView listSysUser(ModelAndView mav) { 44 List<SysUser> list = userService.listSysUser(); 45 mav.addObject("list", list); 46 mav.setViewName("list"); 47 return mav; 48 } 49 50 /** 51 * 跳转到新增用户页面 52 * 53 * @param mav 54 * @return 55 */ 56 @RequestMapping(value = "/add", method = RequestMethod.GET) 57 public ModelAndView addSysUser(ModelAndView mav) { 58 mav.setViewName("add"); 59 return mav; 60 } 61 62 /** 63 * 处理新增用户请求 64 * 65 * @param mav 66 * @param user 67 * @return 68 */ 69 @RequestMapping(value = "/insert", method = RequestMethod.POST) 70 public String insertSysUser(@RequestParam("loginName") String loginName, @RequestParam("name") String name, @RequestParam("password") String password) { 71 SysUser user = new SysUser(); 72 user.setLoginName(loginName); 73 user.setPassword(password); 74 user.setName(name); 75 userService.insertSysUser(user); 76 return "redirect:/user/list"; 77 } 78 79 /** 80 * 处理删除用户请求 81 * 82 * @param mav 83 * @param id 84 * @return 85 */ 86 @RequestMapping(value = "/delete", method = RequestMethod.GET) 87 public String deleteByPrimaryKey(@RequestParam("id") Integer id) { 88 int count = userService.deleteByPrimaryKey(id); 89 if (count == 1) { 90 System.out.println("删除成功!"); 91 }else{ 92 System.out.println("删除失败!"); 93 } 94 return "redirect:/user/list"; 95 } 96 97 /** 98 * 跳转到修改用户页面 99 * 100 * @param mav 101 * @param user 102 * @return 103 */ 104 @RequestMapping(value = "/modify", method = RequestMethod.GET) 105 public String modifyByPrimaryKey(Model model, @RequestParam("id") Integer id) { 106 SysUser user = userService.getByPrimaryKey(id); 107 model.addAttribute("user", user); 108 return "/modify"; 109 } 110 111 /** 112 * 处理修改用户请求 113 * 114 * @param mav 115 * @param user 116 * @return 117 */ 118 @RequestMapping(value = "/update", method = RequestMethod.POST) 119 public String updateByPrimaryKey(@RequestParam("id") Integer id, @RequestParam("loginName") String loginName, @RequestParam("name") String name) { 120 SysUser user = userService.getByPrimaryKey(id); 121 user.setLoginName(loginName); 122 user.setName(name); 123 userService.updateByPrimaryKey(user); 124 return "redirect:/user/list"; 125 } 126 }
com.elanbase.hr.config 配置类包
DruidConfig.java
1 package com.elanbase.hr.config; 2 3 import java.util.Arrays; 4 import java.util.HashMap; 5 import java.util.Map; 6 7 import javax.sql.DataSource; 8 9 import org.springframework.boot.context.properties.ConfigurationProperties; 10 import org.springframework.boot.web.servlet.FilterRegistrationBean; 11 import org.springframework.boot.web.servlet.ServletRegistrationBean; 12 import org.springframework.context.annotation.Bean; 13 import org.springframework.context.annotation.Configuration; 14 15 import com.alibaba.druid.pool.DruidDataSource; 16 import com.alibaba.druid.support.http.StatViewServlet; 17 import com.alibaba.druid.support.http.WebStatFilter; 18 19 @Configuration 20 public class DruidConfig { 21 22 @ConfigurationProperties(prefix = "spring.datasource") 23 @Bean 24 public DataSource druid() { 25 return new DruidDataSource(); 26 } 27 28 // 配置Druid的监控 29 // 1、配置一个管理后台的Servlet 30 @Bean 31 public ServletRegistrationBean statViewServlet() { 32 ServletRegistrationBean bean = new ServletRegistrationBean(new StatViewServlet(), "/druid/*"); 33 Map<String, String> initParams = new HashMap<>(); 34 35 initParams.put("username", "admin"); 36 initParams.put("password", "123456"); 37 initParams.put("allow", "");// 默认就是允许所有访问 38 initParams.put("deny", "192.168.15.21"); 39 40 bean.setInitParameters(initParams); 41 return bean; 42 } 43 44 // 2、配置一个web监控的filter 45 @Bean 46 public FilterRegistrationBean webStatFilter() { 47 FilterRegistrationBean bean = new FilterRegistrationBean(); 48 bean.setFilter(new WebStatFilter()); 49 50 Map<String, String> initParams = new HashMap<>(); 51 initParams.put("exclusions", "*.js,*.css,/druid/*"); 52 53 bean.setInitParameters(initParams); 54 55 bean.setUrlPatterns(Arrays.asList("/*")); 56 57 return bean; 58 } 59 }
com.elanbase.hr.common 公用类包
6、页面:基本CRUD操作
list.html
1 <!DOCTYPE html> 2 <html> 3 <head> 4 <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> 5 <title>list</title> 6 </head> 7 <body> 8 <h1>新增用户</h1> 9 <form action="insert" method="POST"> 10 登录名:<input type="text" id="loginName" name="loginName" /> <br> 11 用户名:<input type="text" id="name" name="name" /> <br> 12 密码:<input type="text" id="password" name="password" /> <br> 13 <input type="submit" value="提交" /> 14 </form> 15 16 <h1>用户列表</h1> 17 <table border="1" style="width: 500px; height: 70px;"> 18 <tr> 19 <td>ID</td> 20 <td>登录名</td> 21 <td>用户名</td> 22 <td>密码</td> 23 <td>操作</td> 24 </tr> 25 26 <#list list as user> 27 <tr> 28 <td>${user.id}</td> 29 <td>${user.loginName}</td> 30 <td>${user.name}</td> 31 <td>${user.password}</td> 32 <td> 33 <a href="delete?id=${user.id}">删除</a> | <a href="modify?id=${user.id}">修改</a> 34 </td> 35 </tr> 36 </#list> 37 </table> 38 39 </body> 40 </html>
modify.html
1 <!DOCTYPE html> 2 <html> 3 <head> 4 <meta charset="UTF-8"> 5 <title>list</title> 6 </head> 7 <body> 8 <h1>修改用户</h1> 9 <form action="../user/update" method="POST"> 10 用户ID:<input type="text" id="id" name="id" value="${user.id}" readonly="readonly" /> <br> 11 登录名:<input type="text" id="loginName" name="loginName" value="${user.loginName}" /> <br> 12 用户名:<input type="text" id="name" name="name" value="${user.name}" /> <br> 13 <input type="submit" value="提交" /> 14 15 </form> 16 17 </body> 18 </html>
http://localhost:8080/elanbasehr/user/list
以上是关于SSM框架整合的主要内容,如果未能解决你的问题,请参考以下文章
520前,我放弃陪女朋友时间,被迫写代码:“SSM框架整合+excel文件上传到数据库+数据更新“