第一步
认识:
用于简化企业应用开发的复杂性
通过'控制反转[loC]+面向切面编程[AOP]'两项技术,统一了对象的配置,查找和生命周期的管理, 实现业务层中不同基础服务的分离
它是轻量级的框架,耗费的系统资源开支较少
由以下几个模块组成,它们提供了企业级开发所需要的基本功能,可以在自己程序中选择使用需要的模块
1. 核心容器和支持工具
---------------
提供该框架基本功能,主要由BEANFACTIORY类组成,采用工厂模式实现反转控制,从而把应用程序的配置和依赖性与实际的应用程序代码分离
2. Application Context模块
它扩展了上面那个模块,提供了对国际化,系统生命周期事件的支持,提供了对JAVA企业级服务的支持,例如访问jndi,集成EJB及电子邮件服务等
3.AOP模块
集成面向切面编程的功能,提供事务等管理服务
4.JDBC和DAO模块
提供了数据库操作中的模板代码,例如连接,处理结果集,关闭,等等从而简体操作代码及释放数据库资源. 而且它还提供了数据库异常层,用来管理异常处理和不同数据库供应商抛出的错误信息,这就简化了数据为操作的错误处理,极大地减少了异常处理的工作量
5.ORM映射模块
注:SPRING并不提供ORM映射的实现,只是提供对其它ORM工具的支持,支持的工具有:JDO,
Hibernate和ibatis等, spring的事务管理都提供对这些ORM工具的支持
6.WEB模块
这个模块是建立了模块二的基础之上的,为基于WEB的应用程序提供上下文.该模块提供了常见的WEB任务处理功能, 简化了处理多部分请求及将请求参数绑定到域对象的工作,并且这时也提供了对struts的支持
7. MVC模块
通过反转控制把业务逻辑和控制逻辑分离开,并且可以声明如何将请求参数绑定到业务对象中.同时在SPRING的MVC中支持各种视力技术,例如JSP,VELOCITY 和 TILES等.
SPRING中内置了日志工具log4j,在使用SPRING之前要对它进行了简单的配置
方法:在src的根目录下创建一个log4j.properties文件,内容如下:
log4j.rootLogger=debug,stdout
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=orgapache.log4j.PatternLayout
log4j.appender.stdout.layout.ConersionPattern=%c{1} - %m%n
///上面这几行含义是:在控制台输出调试信息和标准的控制台输出信息,然后指定了输出的格式
///下面转一篇关于log4j配置的文章
log4j.properties配置文件讲解如下:
# Set root logger level to DEBUG and its only appender to A1
#log4j中有五级logger
#FATAL 0
#ERROR 3
#WARN 4
#INFO 6
#DEBUG 7
配置根Logger,其语法为:
#log4j.rootLogger = [ level ] , appenderName, appenderName, …
log4j.rootLogger=INFO, A1 ,R
#这一句设置以为着所有的log都输出
#如果为log4j.rootLogger=WARN, 则意味着只有WARN,ERROR,FATAL
#被输出,DEBUG,INFO将被屏蔽掉.
# A1 is set to be a ConsoleAppender.
#log4j中Appender有几层如控制台、文件、GUI组件、甚至是套接口服务器、NT的事件记录器、UNIX Syslog守护进程等
#ConsoleAppender输出到控制台
log4j.appender.A1=org.apache.log4j.ConsoleAppender
# A1 使用的输出布局,其中log4j提供4种布局. org.apache.log4j.HTMLLayout(以HTML表格形式布局)
#org.apache.log4j.PatternLayout(可以灵活地指定布局模式),
#org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串),
#org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等等信息)
log4j.appender.A1.layout=org.apache.log4j.PatternLayout
#灵活定义输出格式 具体查看log4j javadoc org.apache.log4j.PatternLayout
#d 时间 ....
log4j.appender.A1.layout.ConversionPattern=%-d{yyyy-MM-dd HH:mm:ss} [%c]-[%p] %m%n
#R 输出到文件 RollingFileAppender的扩展,可以提供一种日志的备份功能。
log4j.appender.R=org.apache.log4j.RollingFileAppender
#日志文件的名称
log4j.appender.R.File=log4j.log
#日志文件的大小
log4j.appender.R.MaxFileSize=100KB
# 保存一个备份文件
log4j.appender.R.MaxBackupIndex=1 log4j.appender.R.layout=org.apache.log4j.TTCCLayout
#log4j.appender.R.layout.ConversionPattern=%-d{yyyy-MM-dd HH:mm:ss} [%c]-[%p] %m%n
配置根Logger,其语法为:
log4j.rootLogger = [ level ] , appenderName, appenderName, ...
level 是日志记录的优先级
appenderName就是指定日志信息输出到哪个地方。您可以同时指定多个输出目的地。
配置日志信息输出目的地Appender,其语法为
log4j.appender.appenderName = fully.qualified.name.of.appender.class
log4j.appender.appenderName.option1 = value1
...
log4j.appender.appenderName.option = valueN
Log4j提供的appender有以下几种:
org.apache.log4j.ConsoleAppender(控制台),
org.apache.log4j.FileAppender(文件),
org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件),
org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件),
org.apache.log4j.WriterAppender(将日志信息以流格式发送到任意指定的地方)
配置日志信息的格式(布局),其语法为:
log4j.appender.appenderName.layout = fully.qualified.name.of.layout.class
log4j.appender.appenderName.layout.option1 = value1
....
log4j.appender.appenderName.layout.option = valueN
Log4j提供的layout有以下几种:
org.apache.log4j.HTMLLayout(以HTML表格形式布局),
org.apache.log4j.PatternLayout(可以灵活地指定布局模式),
org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串),
org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等等信息)