前言:上一篇讲了博客项目的搭建!这一篇是SSM框架的整合,并用TOMCAT启动
1、使用MAVEN的pom.xml文件进行项目骨架的填充。(也就是添加SSM的各种JAR包,其次pom文件实际是(project object model的缩写!))
2、使用各种配置文件进行SSM框架的整合。列如数据库的连接信息、日志的信息、spring和mybatis的整合等等!
3、配置web.xml文件,web服务的启动,各种过滤器、servlet、的配置。
4、配置TOMCAT,将项目部署上去。然后通过localhost:8080去访问。
在进行添加jar包前,对maven不是很了解的童鞋可以参靠下此篇博文!MAVEN仓库
对MAVEN有比较全面的了解的同学们可以继续开始这一步,进行SSM依赖包的导入。
实际上有N多的JAR需要导入!但是目前我们先让我们的项目跑起来的JAR包导入就好了,各个JAR的作用我会通过注释来标注!对于这一部分我认为新手需要好好记忆各个JAR包的作用。
在 LIWEBLOG-WEB 子工程的 pom.xml 中添加以下代码:(ps:切记不是父工程的pom文件。)
UTF-8
1.7
1.7
4.2.5.RELEASE
3.2.8
5.1.29
1.7.18
1.2.17
4.1.3.RELEASE
1.7.1.RELEASE
jstl
jstl
1.2
javax
javaee-api
7.0
org.springframework
spring-core
${spring.version}
org.springframework
spring-web
${spring.version}
org.springframework
spring-oxm
${spring.version}
org.springframework
spring-tx
${spring.version}
org.springframework
spring-jdbc
${spring.version}
org.springframework
spring-webmvc
${spring.version}
org.springframework
spring-context
${spring.version}
org.springframework
spring-context-support
${spring.version}
org.springframework
spring-aop
${spring.version}
org.springframework
spring-test
${spring.version}
org.mybatis
mybatis
${mybatis.version}
org.mybatis
mybatis-spring
1.2.2
mysql
mysql-connector-java
${mysql-driver.version}
commons-dbcp
commons-dbcp
1.2.2
log4j
log4j
${log4j.version}
org.slf4j
slf4j-api
${slf4j.version}
org.slf4j
slf4j-log4j12
${slf4j.version}
org.springframework
spring-jms
${spring.version}
org.apache.xbean
xbean-spring
4.0
commons-beanutils
commons-beanutils
1.9.3
tk.mybatis
mapper
3.1.2
junit
junit
4.11
test
写完以后进行。保存,如果小伙伴们看到你的POM文件报红,请不要惊慌。这是因为你没有从网上下载这些JAR包。
此时你只需要通过 Alt+Enter 组合键进行下载即可。
然后你会发现你得IDEA的依赖包会多些东西出来。
到此为止我们对于SSM基本的jar包导入已经完成了。接下来我们要进行配置文件的编写。
这一小节,我们将完成配置文件的配置。配置文件的加载顺序以及各配置文件有什么作用,我会在最后进行介绍。
各配置文件位置如下图:
整个文件是用来连接数据库的配置文件其中的文件内容主要有,数据库的名字。连接信息等!
配置信息如下。
driverClasss=com.mysql.jdbc.Driver
jdbcUrl=jdbc:mysql://localhost:3306/liweiblog_db?useUnicode=true&characterEncoding=utf-8&zeroDateTimeBehavior=convertToNull
username=root
password=123456
#定义初始连接数
initialSize=0
#定义最大连接数
maxActive=20
#定义最大空闲
maxIdle=20
#定义最小空闲
minIdle=1
#定义最长等待时间
maxWait=60000
其中,username代表的数据库用户名,password代表数据库密码。3306是mysql的端口号,liweiblog_db是我接下来的数据库名称。
log4j.properties 为 log4j 日志配置文件,主要将程序中打印的日志信息输出到控制台、保存到目录文件,可以通过配置设置日志文件的输出级别、格式、输出路径等。
配置代码如下:
log4j.rootLogger=DEBUG,Console,File
#日志输出到控制台
og4j.appender.Console=org.apache.log4j.ConsoleAppender
#指定输出到控制台
log4j.appender.Console.Target=System.out
#灵活地指定布局模式
log4j.appender.Console.layout=org.apache.log4j.PatternLayout
#日志输出格式设置
log4j.appender.Console.layout.ConversionPattern=[%p][%t][%d{yyyy-MM-dd HH\:mm\:ss}][%C] - %m%n
#日志输出到文件
log4j.appender.File=org.apache.log4j.RollingFileAppender
#日志存放位置
log4j.appender.File.File=C/Users/HAND_WEILI/Desktop/test/LIWEIBLOG_LOG/run.log
#单个日志文件大小设置
log4j.appender.File.MaxFileSize=10MB
#输出日志,如果换成DEBUG表示输出DEBUG以上级别日志
log4j.appender.File.Threshold=ALL
log4j.appender.File.layout=org.apache.log4j.PatternLayout
log4j.appender.File.layout.ConversionPattern=[%p][%t][%d{yyyy-MM-dd HH\:mm\:ss}][%C] - %m%n
下面我们解释下以上代码中需要注意的地方。
(1)日志输出级别分为以下四种,优先级别为:
ERROR > WARN > INFO > DEBUG
输出原则为:程序会打印出高于或等于所设置级别的日志,设置的日志等级越高,打印出来的日志就越少,即:
设置级别为 ERROR 只会打印出 ERROR 日志;
设置级别为 WARN 会打印出 ERROR 和 WRAN 日志;
设置级别为 INFO 会打印出 ERROR、WARN 和 INFO 日志;
设置为 DEBUG 会打印出所有日志。
本案例中 log4j.rootLogger=DEBUG,Console,File
表示输出 DEBUG 以上级别日志。
(2)上面代码中出现的 %m
、%p
、%d
、%c
、%n
……分别代表的含义如下所示:
%m 输出代码中指定的消息
%p 输出优先级,即DEBUG,INFO,WARN,ERROR,FATAL
%r 输出自应用启动到输出该log信息耗费的毫秒数
%c 输出所属的类目,通常就是所在类的全名
%t 输出产生该日志事件的线程名
%n 输出一个回车换行符,Windows平台为“rn”,Unix平台为“n”
%d 输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyyy MMM dd HH:mm:ss,SSS},输出类似:2002年10月18日 :10:28,921
%l 输出日志事件的发生位置,包括类目名、发生的线程,以及在代码中的行数。
%x Used to output the NDC (nested diagnostic context) associated with the thread that generated the logging event
%X Used to output the MDC (mapped diagnostic context) associated with the thread that generated the logging event for specified key
(3)如下代码用来设定当文件到达设定大小时产生一个新的文件。
log4j.appender.File=org.apache.log4j.RollingFileAppender
将 RollingFileAppender 换成 DailyRollingFileAppender,则表示每天产生一个日志文件。
(4)可以在下面的代码中设置你的日志文件的存放位置。
log4j.appender.File.File=D/wly/git/dreamland/logs/run.log
srping-mvc.xml 为 SpringMVC 核心配置文件,主要包括 Controller 层的包扫描、视图模式配置(跳转路径的前后缀)、文件上传配置、静态资源处理等。另外值得一提的是,MVC实际上是通过设计模式的观察者模式改变而来的!
配置代码如下,关键地方均有注释说明:
text/html;charset=UTF-8
当你创建完这个以后会出现爆红。分别是在自动扫描和对静态资源访问的出现的爆红,原因就是你没有想对应的文件夹所以会出现报错。
在 java 目录右键 new -> Package ->com.liwei.blog.controller。
然后在 webapp 下右键 new -> Directory 分别创建 css、js 和 images 文件夹
spring-mybatis.xml 为 Spring 和 Mybatis 整合配置文件,主要进行扫描包的配置、数据源的配置、映射文件的配置、事务管理配置等,配置文件中都有注释,这里不再赘述。
配置代码如下:
classpath:jdbc.properties
这一块是整合的一个关键点,需要好好好记住此处的各种配置文件。当然现在的SPRINGBOOT不用这么麻烦但是知道以后会很好的哦!
mybatis-config.xml 是 MyBatis 的核心配置文件,包括驼峰命名、别名、通用 mapper、分页插件配置等。
配置代码如下,关键地方均有注释说明:
上面代码中,com.liwei.blog.entity对应的是实体类包路径,之后新建实体时就放在该路径下:
web.xml 为 Web 容器的配置文件,用来初始化配置信息,主要定义了:
配置代码如下所示:
dreamland-web
contextConfigLocation
classpath*:spring-mybatis.xml
log4jConfigLocation
classpath:log4j.properties
encodingFilter
org.springframework.web.filter.CharacterEncodingFilter
encoding
UTF-8
encodingFilter
/*
org.springframework.web.context.ContextLoaderListener
org.springframework.web.util.IntrospectorCleanupListener
SpringMVC
org.springframework.web.servlet.DispatcherServlet
contextConfigLocation
classpath:spring-mvc.xml
1
true
SpringMVC
/
default
*.xml
default
*.css
index.jsp
15
到此,SSM框架的配置信息。已经完成了。然后接下来就是将对应的项目给部署到TOMCAT上去了。
Web 容器加载配置文件顺序
上面,我们把配置文件配置好了,那怎样才能起作用呢?这就需要 Web 容器来加载了。Web 容器加载配置文件的过程如下。
启动 Tomcat 后,Web 容器首先加载 web.xml 文件。
web.xml 文件是创建 Web 项目所需要的配置文件,用来初始化配置信息,主要包含拦截器、过滤器、servlet 等的配置,它的位置在项目 WEB-INF 目录下。
在 web.xml 的
中加载其他 XML 和 log4j.properties 文件,代码如下:
contextConfigLocation
classpath*:spring-mybatis.xml,
classpath*:applicationContext-redis.xml,
classpath*:applicationContext-activemq.xml,
log4jConfigLocation
classpath:log4j.properties
其中 param-name 的名称是固定格式,param-value 是要加载的配置文件名,多个用逗号隔开,通过 Ctrl+鼠标左键可定位到相应配置文件。
接着,根据 spring-mybatis.xml 中的 PropertiesFactoryBean 加载多个 properties 文件,代码如下:
classpath:jdbc.properties
classpath:redis.properties
通过 property 标签内的 list 标签可以加载多个 properties 文件,value 标签内就是具体的 properties 文件的路径,通过 Ctrl+鼠标左键可以定位到相应的文件。
根据 spring-mybatis.xml 的 SqlSessionFactoryBean 加载 mybatis 核心配置文件 mybatis-config.xml 以及其他映射文件
其中 property 标签的 name 值是固定的,通过该属性加载对应的 value 中的值,value 的值是配置文件的路径,通过 Ctrl+鼠标左键可访问该文件。
然后,加载前端控制器 DispatcherServlet 的配置文件 srping-mvc.xml。
SpringMVC
org.springframework.web.servlet.DispatcherServlet
contextConfigLocation
classpath:spring-mvc.xml
1
true
SpringMVC
/
其中 init-param 标签是前端控制器的初始化参数配置,param-name 参数名为固定值,param-value 参数值为具体的配置文件路径,以此来加载对应的配置文件。
的正数值越小,启动该 Servlet 的优先级越高。
这样所有的配置文件就加载完毕了!
powerdesinger安装教程