搭建SSM框架:SpringMVC + Spring + MyBatis
来源:互联网 发布:自学钢琴 知乎 编辑:程序博客网 时间:2024/05/22 08:27
在写代码之前我们先了解一下这三个框架分别是干什么的?
相信大以前也看过不少这些概念,我这就用大白话来讲,如果之前有了解过可以跳过这一大段,直接看代码!
SpringMVC:它用于web层,相当于controller(等价于传统的servlet和struts的action),用来处理用户请求。举个例子,用户在地址栏输入http://网站域名/login,那么springmvc就会拦截到这个请求,并且调用controller层中相应的方法,(中间可能包含验证用户名和密码的业务逻辑,以及查询数据库操作,但这些都不是springmvc的职责),最终把结果返回给用户,并且返回相应的页面(当然也可以只反馈josn/xml等格式数据)。springmvc就是做前面和后面过程的活,与用户打交道!!
Spring:太强大了,以至于我无法用一个词或一句话来概括它。但与我们平时开发接触最多的估计就是IOC容器,它可以装载bean(也就是我们java中的类,当然也包括service dao里面的),有了这个机制,我们就不用在每次使用这个类的时候为它初始化,很少看到关键字new。另外spring的aop,事务管理等等都是我们经常用到的。
MyBatis:如果你问我它跟鼎鼎大名的Hibernate有什么区别?我只想说,他更符合我的需求。第一,它能自由控制sql,这会让有数据库经验的人(当然不是说我啦~捂脸~)编写的代码能搞提升数据库访问的效率。第二,它可以使用xml的方式来组织管理我们的sql,因为一般程序出错很多情况下是sql出错,别人接手代码后能快速找到出错地方,甚至可以优化原来写的sql。
SSM框架整合配置
好了,前面bb那么多,下面我们真正开始敲代码了~
首先我们打开IED,我这里用的是eclipse(当然,用IDE也是可以的),创建一个动态web项目,建立好相应的目录结构(重点!)
(打马赛克的地方目前还不用到)
我说一下每个目录都有什么用吧
这个目录结构同时也遵循maven的目录规范~
我先新建好几个必要的包,并为大家讲解一下每个包的作用,顺便理清一下后台的思路~
还有最后一步基础工作,导入我们相应的jar包,我使用的是maven来管理我们的jar,所以只需要在poom.xml
中加入相应的依赖就好了,如果不使用maven的可以自己去官网下载相应的jar,放到项目WEB-INF/lib目录下。关于maven的学习大家可以看慕课网的视频教程,这里就不展开了。我把项目用到的jar都写在下面,版本都不是最新的,大家有经验的话可以自己调整版本号。另外,所有jar都会与项目一起打包放到我的github上,喜欢的给个star吧~
poom.xml
<code
class
=
"language-xml hljs "
><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.0http://maven.apache.org/maven-v4_0_0.xsd"
>
<modelversion>
4.0
.
0
</modelversion>
<groupid>com.soecode.ssm</groupid>
ssm</artifactid>
<packaging>war</packaging>
<version>
0.0
.
1
-SNAPSHOT</version>
<name>ssm Maven Webapp</name>
<url>http:
//github.com/liyifeng1994/ssm</url>
<dependencies>
<!-- 单元测试 -->
<dependency>
<groupid>junit</groupid>
junit</artifactid>
<version>
4.11
</version>
</dependency>
<!--
1
.日志 -->
<!-- 实现slf4j接口并整合 -->
<dependency>
<groupid>ch.qos.logback</groupid>
logback-classic</artifactid>
<version>
1.1
.
1
</version>
</dependency>
<!--
2
.数据库 -->
<dependency>
<groupid>mysql</groupid>
mysql-connector-java</artifactid>
<version>
5.1
.
37
</version>
<scope>runtime</scope>
</dependency>
<dependency>
<groupid>c3p0</groupid>
c3p0</artifactid>
<version>
0.9
.
1.2
</version>
</dependency>
<!-- DAO: MyBatis -->
<dependency>
<groupid>org.mybatis</groupid>
mybatis</artifactid>
<version>
3.3
.
0
</version>
</dependency>
<dependency>
<groupid>org.mybatis</groupid>
mybatis-spring</artifactid>
<version>
1.2
.
3
</version>
</dependency>
<!--
3
.Servlet web -->
<dependency>
<groupid>taglibs</groupid>
standard</artifactid>
<version>
1.1
.
2
</version>
</dependency>
<dependency>
<groupid>jstl</groupid>
jstl</artifactid>
<version>
1.2
</version>
</dependency>
<dependency>
<groupid>com.fasterxml.jackson.core</groupid>
jackson-databind</artifactid>
<version>
2.5
.
4
</version>
</dependency>
<dependency>
<groupid>javax.servlet</groupid>
javax.servlet-api</artifactid>
<version>
3.1
.
0
</version>
</dependency>
<!--
4
.Spring -->
<!--
1
)Spring核心 -->
<dependency>
<groupid>org.springframework</groupid>
spring-core</artifactid>
<version>
4.1
.
7
.RELEASE</version>
</dependency>
<dependency>
<groupid>org.springframework</groupid>
spring-beans</artifactid>
<version>
4.1
.
7
.RELEASE</version>
</dependency>
<dependency>
<groupid>org.springframework</groupid>
spring-context</artifactid>
<version>
4.1
.
7
.RELEASE</version>
</dependency>
<!--
2
)Spring DAO层 -->
<dependency>
<groupid>org.springframework</groupid>
spring-jdbc</artifactid>
<version>
4.1
.
7
.RELEASE</version>
</dependency>
<dependency>
<groupid>org.springframework</groupid>
spring-tx</artifactid>
<version>
4.1
.
7
.RELEASE</version>
</dependency>
<!--
3
)Spring web -->
<dependency>
<groupid>org.springframework</groupid>
spring-web</artifactid>
<version>
4.1
.
7
.RELEASE</version>
</dependency>
<dependency>
<groupid>org.springframework</groupid>
spring-webmvc</artifactid>
<version>
4.1
.
7
.RELEASE</version>
</dependency>
<!--
4
)Spring test -->
<dependency>
<groupid>org.springframework</groupid>
spring-test</artifactid>
<version>
4.1
.
7
.RELEASE</version>
</dependency>
<!-- redis客户端:Jedis -->
<dependency>
<groupid>redis.clients</groupid>
jedis</artifactid>
<version>
2.7
.
3
</version>
</dependency>
<dependency>
<groupid>com.dyuproject.protostuff</groupid>
<artifactid>protostuff-core</artifactid>
<version>
1.0
.
8
</version>
</dependency>
<dependency>
<groupid>com.dyuproject.protostuff</groupid>
<artifactid>protostuff-runtime</artifactid>
<version>
1.0
.
8
</version>
</dependency>
<!-- Map工具类 -->
<dependency>
<groupid>commons-collections</groupid>
<artifactid>commons-collections</artifactid>
<version>
3.2
</version>
</dependency>
</dependencies>
<build>
<finalname>ssm</finalname>
</build>
</project>
</code>
下面真的要开始进行编码工作了,坚持到这里辛苦大家了~
第一步:我们先在spring
文件夹里新建spring-dao.xml
文件,因为spring的配置太多,我们这里分三层,分别是dao service web。
配置连接属性,可以不读配置项文件直接在这里写死 配置c3p0,只配了几个常用的 配置SqlSessionFactory对象(mybatis) 扫描dao层接口,动态实现dao接口,也就是说不需要daoImpl,sql和参数都写在xml文件上
spring-dao.xml
<code
class
=
"language-xml hljs "
><!--?xml version=
"1.0"
encoding=
"UTF-8"
?-->
<beans xmlns=
"http://www.springframework.org/schema/beans"
xmlns:context=
"http://www.springframework.org/schema/context"
xmlns:xsi=
"http://www.w3.org/2001/XMLSchema-instance"
xsi:schemalocation="http://www.springframework.org/schema/beans
http:
//www.springframework.org/schema/beans/spring-beans.xsd
http:
//www.springframework.org/schema/context
http:
//www.springframework.org/schema/context/spring-context.xsd">
<!-- 配置整合mybatis过程 -->
<!--
1
.配置数据库相关参数properties的属性:${url} -->
<context:property-placeholder location=
"classpath:jdbc.properties"
>
<!--
2
.数据库连接池 -->
<bean
class
=
"com.mchange.v2.c3p0.ComboPooledDataSource"
id=
"dataSource"
>
<!-- 配置连接池属性 -->
<property name=
"driverClass"
value=
"${jdbc.driver}"
>
<property name=
"jdbcUrl"
value=
"${jdbc.url}"
>
<property name=
"user"
value=
"${jdbc.username}"
>
<property name=
"password"
value=
"${jdbc.password}"
>
<!-- c3p0连接池的私有属性 -->
<property name=
"maxPoolSize"
value=
"30"
>
<property name=
"minPoolSize"
value=
"10"
>
<!-- 关闭连接后不自动commit -->
<property name=
"autoCommitOnClose"
value=
"false"
>
<!-- 获取连接超时时间 -->
<property name=
"checkoutTimeout"
value=
"10000"
>
<!-- 当获取连接失败重试次数 -->
<property name=
"acquireRetryAttempts"
value=
"2"
>
</property></property></property></property></property></property></property></property></property></bean>
<!--
3
.配置SqlSessionFactory对象 -->
<bean
class
=
"org.mybatis.spring.SqlSessionFactoryBean"
id=
"sqlSessionFactory"
>
<!-- 注入数据库连接池 -->
<property name=
"dataSource"
ref=
"dataSource"
>
<!-- 配置MyBaties全局配置文件:mybatis-config.xml -->
<property name=
"configLocation"
value=
"classpath:mybatis-config.xml"
>
<!-- 扫描entity包 使用别名 -->
<property name=
"typeAliasesPackage"
value=
"com.soecode.lyf.entity"
>
<!-- 扫描sql配置文件:mapper需要的xml文件 -->
<property name=
"mapperLocations"
value=
"classpath:mapper/*.xml"
>
</property></property></property></property></bean>
<!--
4
.配置扫描Dao接口包,动态实现Dao接口,注入到spring容器中 -->
<bean
class
=
"org.mybatis.spring.mapper.MapperScannerConfigurer"
>
<!-- 注入sqlSessionFactory -->
<property name=
"sqlSessionFactoryBeanName"
value=
"sqlSessionFactory"
>
<!-- 给出需要扫描Dao接口包 -->
<property name=
"basePackage"
value=
"com.soecode.lyf.dao"
>
</property></property></bean>
</context:property-placeholder></beans></code>
因为数据库配置相关参数是读取配置文件,所以在resources
文件夹里新建一个jdbc.properties
文件,存放我们4个最常见的数据库连接属性,这是我本地的,大家记得修改呀~还有喜欢传到github上“大头虾们”记得删掉密码,不然别人就很容易得到你服务器的数据库配置信息,然后干一些羞羞的事情,你懂的!!
jdbc.properties
<code
class
=
"language-properties hljs avrasm"
>jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql:
//localhost:3307/ssm?useUnicode=true&characterEncoding=utf8
jdbc.username=root
jdbc.password=</code>
友情提示:配置文件中的jdbc.username,如果写成username,可能会与系统环境中的username变量冲突,所以到时候真正连接数据库的时候,用户名就被替换成系统中的用户名(有得可能是administrator),那肯定是连接不成功的,这里有个小坑,我被坑了一晚上!!
因为这里用到了mybatis,所以需要配置mybatis核心文件,在recources
文件夹里新建mybatis-config.xml
文件。
mybatis-config.xml
<code
class
=
"language-xml hljs "
><!--?xml version=
"1.0"
encoding=
"UTF-8"
?-->
<configuration>
<!-- 配置全局属性 -->
<settings>
<!-- 使用jdbc的getGeneratedKeys获取数据库自增主键值 -->
<setting name=
"useGeneratedKeys"
value=
"true"
>
<!-- 使用列别名替换列名 默认:
true
-->
<setting name=
"useColumnLabel"
value=
"true"
>
<!-- 开启驼峰命名转换:Table{create_time} -> Entity{createTime} -->
<setting name=
"mapUnderscoreToCamelCase"
value=
"true"
>
</setting></setting></setting></settings>
</configuration></code>
第二步:刚弄好dao层,接下来到service层了。在spring
文件夹里新建spring-service.xml
文件。
spring-service.xml
<code
class
=
"language-xml hljs "
><!--?xml version=
"1.0"
encoding=
"UTF-8"
?-->
<beans xmlns=
"http://www.springframework.org/schema/beans"
xmlns:context=
"http://www.springframework.org/schema/context"
xmlns:tx=
"http://www.springframework.org/schema/tx"
xmlns:xsi=
"http://www.w3.org/2001/XMLSchema-instance"
xsi:schemalocation="http://www.springframework.org/schema/beans
http:
//www.springframework.org/schema/beans/spring-beans.xsd
http:
//www.springframework.org/schema/context
http:
//www.springframework.org/schema/context/spring-context.xsd
http:
//www.springframework.org/schema/tx
http:
//www.springframework.org/schema/tx/spring-tx.xsd">
<!-- 扫描service包下所有使用注解的类型 -->
<context:component-scan base-
package
=
"com.soecode.lyf.service"
>
<!-- 配置事务管理器 -->
<bean
class
=
"org.springframework.jdbc.datasource.DataSourceTransactionManager"
id=
"transactionManager"
>
<!-- 注入数据库连接池 -->
<property name=
"dataSource"
ref=
"dataSource"
>
</property></bean>
<!-- 配置基于注解的声明式事务 -->
<tx:annotation-driven transaction-manager=
"transactionManager"
>
</tx:annotation-driven></context:component-scan></beans></code>
第三步:配置web层,在spring
文件夹里新建spring-web.xml
文件。
spring-web.xml
<code
class
=
"language-xml hljs "
><!--?xml version=
"1.0"
encoding=
"UTF-8"
?-->
<beans xmlns=
"http://www.springframework.org/schema/beans"
xmlns:context=
"http://www.springframework.org/schema/context"
xmlns:mvc=
"http://www.springframework.org/schema/mvc"
xmlns:xsi=
"http://www.w3.org/2001/XMLSchema-instance"
xsi:schemalocation="http://www.springframework.org/schema/beans
http:
//www.springframework.org/schema/beans/spring-beans.xsd
http:
//www.springframework.org/schema/context
http:
//www.springframework.org/schema/context/spring-context.xsd
http:
//www.springframework.org/schema/mvc
http:
//www.springframework.org/schema/mvc/spring-mvc-3.0.xsd">
<!-- 配置SpringMVC -->
<!--
1
.开启SpringMVC注解模式 -->
<!-- 简化配置:
(
1
)自动注册DefaultAnootationHandlerMapping,AnotationMethodHandlerAdapter
(
2
)提供一些列:数据绑定,数字和日期的format
@NumberFormat
,
@DateTimeFormat
, xml,json默认读写支持
-->
<mvc:annotation-driven>
<!--
2
.静态资源默认servlet配置
(
1
)加入对静态资源的处理:js,gif,png
(
2
)允许使用
"/"
做整体映射
-->
<mvc:
default
-servlet-handler>
<!--
3
.配置jsp 显示ViewResolver -->
<bean
class
=
"org.springframework.web.servlet.view.InternalResourceViewResolver"
>
<property name=
"viewClass"
value=
"org.springframework.web.servlet.view.JstlView"
>
<property name=
"prefix"
value=
"/WEB-INF/jsp/"
>
<property name=
"suffix"
value=
".jsp"
>
</property></property></property></bean>
<!--
4
.扫描web相关的bean -->
<context:component-scan base-
package
=
"com.soecode.lyf.web"
>
</context:component-scan></mvc:
default
-servlet-handler></mvc:annotation-driven></beans></code>
第四步:最后就是修改web.xml
文件了,它在webapp
的WEB-INF
下。
web.xml
<code
class
=
"language-xml hljs "
><web-app metadata-complete=
"true"
version=
"3.1"
xmlns=
"http://xmlns.jcp.org/xml/ns/javaee"
xmlns:xsi=
"http://www.w3.org/2001/XMLSchema-instance"
xsi:schemalocation="http://xmlns.jcp.org/xml/ns/javaee
http:
//xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd">
<!-- 如果是用mvn命令生成的xml,需要修改servlet版本为
3.1
-->
<!-- 配置DispatcherServlet -->
<servlet>
<servlet-name>seckill-dispatcher</servlet-name>
<servlet-
class
>org.springframework.web.servlet.DispatcherServlet</servlet-
class
>
<!-- 配置springMVC需要加载的配置文件
spring-dao.xml,spring-service.xml,spring-web.xml
Mybatis - > spring -> springmvc
-->
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:spring/spring-*.xml</param-value>
</init-param>
</servlet>
<servlet-mapping>
<servlet-name>seckill-dispatcher</servlet-name>
<!-- 默认匹配所有的请求 -->
<url-pattern>/</url-pattern>
</servlet-mapping>
</web-app>
</code>
我们在项目中经常会使用到日志,所以这里还有配置日志xml,在resources
文件夹里新建logback.xml
文件,所给出的日志输出格式也是最基本的控制台s呼出,大家有兴趣查看logback官方文档。
logback.xml
<code
class
=
"language-xml hljs "
><!--?xml version=
"1.0"
encoding=
"UTF-8"
?-->
<configuration debug=
"true"
>
<!-- encoders are by
default
assigned the type ch.qos.logback.classic.encoder.PatternLayoutEncoder -->
<encoder>
<pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{
36
} - %msg%n</pattern>
</encoder>
</appender>
<root level=
"debug"
>
</appender-ref></root>
</configuration></code>
到目前为止,我们一共写了7个配置文件,我们一起来看下最终的配置文件结构图。
针对此篇文章,下篇文章会做一个demo,采用SSM框架给大家搭建一个栗子。
- Spring,SpringMVC,Mybatis (SSM)框架的搭建
- SSM框架搭建(Spring+SpringMVC+MyBatis)
- 整合Spring SpringMvc Mybatis,搭建SSM框架
- 搭建ssm框架:Spring SpringMVC Mybatis
- Spring + SpringMvc + Mybatis 搭建SSM框架
- 搭建SSM框架:SpringMVC + Spring + MyBatis
- SSM(spring +springmvc +mybatis)框架搭建
- SSM框架搭建(SpringMVC+Spring+Mybatis)
- SSM(Spring+SpringMVC+Mybatis)框架搭建
- 使用Spring、SpringMvc、MyBatis搭建SSM框架
- SSM(SpringMVC+Spring+Mybatis)框架搭建
- 使用Spring、SpringMvc、MyBatis搭建SSM框架
- 使用Spring、SpringMvc、MyBatis搭建SSM框架
- SSM框架:SpringMVC + Spring + MyBatis
- java开发SSM框架的搭建(SpringMVC+Spring+MyBatis)
- SSM(Spring+SpringMVC+MyBatis)开发框架的搭建个人总结
- MyEclipse SSM(Spring+SpringMVC+MyBatis)框架搭建
- ssm(springmvc+spring+mybatis)框架的搭建
- Cocos2dx物理引擎(一)
- spring aop
- javaweb中使用百度、谷歌地图进行定位
- Android AS停留卡在building Gradle project
- 开发环境 生产环境 测试环境的基本理解和区别
- 搭建SSM框架:SpringMVC + Spring + MyBatis
- MOEA/D的学习笔记
- 一些现在才知道的SB东西
- K-means的Python实现
- Docker采用Dockerfile方式构建Tomcat容器镜像
- 1295: 调和级数
- char*转tchar*
- elasticsearch for java之Document APIs【增删改查】
- input js 过滤表情