您的位置:首页 > 编程语言 > Java开发

基于Spring+JDBC的用户管理系统

2006-11-15 15:53 369 查看
 
第2章基于Spring+JDBC的用户管理系统
前面章节中为读者讲述了Spring的相关知识点,本章主要为读者讲解如何基于Spring进行Web应用程序开发。通过本章的学习,读者可以掌握DisplayTag、Sitemesh、Log4j、PostgreSQL、ehcache和国际化等的使用。
本章知识点
1.      SiteMesh的使用
2.      DisplayTag
3.      支持多种数据库
4.      国际化的试用
5.      Log4j的使用
6.      集成Spring
7.      JDBC的应用

2.1. Spring框架的特点

Spring Web MVC框架提供了大量独特的功能,包括:
l         清晰的角色划分:控制器(controller)、验证器(validator)、命令对象(command object)、表单对象(form object)、模型对象(model object)、Servlet分发器(DispatcherServlet)、处理器映射(handler mapping)、视图解析器(view resolver)等等。每一个角色都由一个专门的对象来完成。
l         强大而简单的配置:将框架类和应用类都作为JavaBean配置,支持在一个context中引用其他context的中JavaBean,例如,在web控制器中对业务对象和验证器(validator)的引用。
l         可适配、非侵入的controller:你可以根据不同的情况,选择合适的控制器子类(simple型、command型、form型、wizard型、multi-action型或者自定义),而不是从单一控制器(比如Action/ActionForm)继承。
l         可重用的业务代码:你可以使用现有的业务对象作为命令或表单对象,而不需要在类似ActionForm的子类中重复它们的定义。
l         可定制的binding 和validation:比如将类型不匹配作为应用级的验证错误,这可以保存错误的值。再比如本地化的日期和数字绑定等等。在其他某些框架中,你只能使用字符串表单对象,需要手动解析它并转换到业务对象。
l         可定制的handler mapping和view resolver:Spring提供从最简单的的URL映射,到复杂的、专用的定制策略。某些MVC框架强制开发人员使用某一种方法,与之相比,Spring更加灵活。
l         可定制的本地化和主题(theme)解析:支持在JSP中可选择使用Spring标签库、支持JSTL、支持Velocity(不需要额外的中间层)等等。
l         简单而强大的标签库(Spring Tag Library):这个库支持诸如数据绑定和主题之类的功能。它提供在标记方面的最大灵活性。
l         新增加的表单标签库:在Spring2.0中刚刚引入的表单标签库,使得在JSP中编写表单更加容易。
l         Spring Bean的生命周期可以被限制在当前的HTTP Request或者HTTP Session。准确的说,这个功能属于Sping MVC用到的WebApplicationContext 容器,而不属于Spring MVC框架本身。

 
[align=left]本系统以Spring+JDBC来实现用户管理系统,采用模块化设计,包含功能:[/align]

2.1.1.1 用户管理

[align=left]用户管理功能实现了管理用户管理系统的用户功能,如用户的增加、修改、删除、按各种方式提供的查询。[/align]

2.2 系统界面预览

[align=left]通过对系统架构和功能的理解,下面为读者提供本系统的相关界面:[/align]

2.2.1首页

[align=left]用户管理的首页,如图2-2所示:[/align]
[align=left] [/align]
[align=left]图2-2 用户管理系统首页[/align]

2.2.2用户管理菜单导航栏

[align=left]单击上图中的用户管理菜单,如图2-3所示的界面:[/align]
[align=left] [/align]
[align=left]图2-3 用户管理菜单导航栏[/align]

2.2.3按用户编码查询用户

[align=left]单击上图中的按用户编码查询用户链接,如图2-4所示的界面:[/align]
[align=left] [/align]
[align=left]图2-4 按用户编码查询用户界面[/align]

2.2.4增加用户

[align=left]单击增加用户按钮,如图2-5所示的界面:[/align]
[align=left] [/align]
[align=left]图2-5 增加用户界面[/align]

2.2.5编辑用户

[align=left]选中列表中的用户,如图2-6所示的界面:[/align]
[align=left] [/align]
图2-6 编辑用户界面

2.2.6删除用户

[align=left]选中列表中的用户,单击删除按钮,如图2-7所示的界面:[/align]
[align=left] [/align]
图2-7 删除用户界面

2.2.7排序

[align=left]单击列表中的任何列进行用户数据排序,如图2-7所示的界面:[/align]
[align=left] [/align]
图2-7排序

2.2.7分页

[align=left]单击列表中的任何列进行用户数据排序,如图2-7所示的界面:[/align]
[align=left] [/align]
图2-7分页

2.2.7数据导出

[align=left]单击列表中的任何列进行用户数据排序,如图2-7所示的界面:[/align]
[align=left] [/align]
图2-7数据导出

  
 

2.3数据库逻辑结构设计

下面为大家分析数据库逻辑结构设计。

2.3.1用户(app_user)

表2-1所示为用户表,主要存储用户信息
字段
类型名称
是否为空
默认值
描述
Id    
Bigint

 
序号
First_name
Varchar(50)

 

Last_name
Varchar(50)

 

Birthday
timestamp
 
 
出生日期
创建app_user表的SQL如下:
create table app_user (id bigint not null primary key, first_name varchar(50), last_name varchar(50), birthday timestamp);

2.3.2基于PostGreSQL创建用户表

 

2.4工程目录

[align=left]上面为读者讲述了如果完整开发一个模块的功能,关于本实例的其他功能和实现,读者参考上面部分,自行光盘中所附代码,下面为大家讲述本实例的目录结构,如图2-8所示:[/align]
[align=left] [/align]
[align=left]图2-8 本实例工程目录[/align]
[align=left]其中,[/align]
[align=left]1、.settings为工程的默认目录,保存工程中的一些设置信息;[/align]
[align=left]2、src为工程的源代码文件目录,其中[/align]
[align=left]a.           com.my37signals为本实例的主要包名;[/align]
[align=left]b.           com.my37signals.dao包中存放所有接口类文件;[/align]
[align=left]c.            com.my37signals.dao.jdbc包中存放所有Spring实现类文件;[/align]
[align=left]d.           com.my37signals.model包中存放模型类文件;[/align]
[align=left]e.           com.my37signals.service包中存放服务类文件;[/align]
[align=left]f.             com.my37signals.service.impl包中存放服务实现类文件;[/align]
[align=left]g.           com.my37signals.web包中存放Spring的控制器类文件;[/align]
[align=left]3、WebContent为工程的web内容目录,主要存放JSP、Lib和相关配置文件,相关文件如下:[/align]
[align=left]a)      404.jsp,404错误显示网页;   [/align]
[align=left]b)      dataAccessFailure.jsp ,数据访问失败网页;[/align]
[align=left]c)       error.jsp,错误信息网页;[/align]
[align=left]d)      index.jsp,首页;               [/align]
[align=left]e)      messages.jsp,信息显示网页;            [/align]
[align=left]f)        taglibs.jsp,类库引入文件;             [/align]
[align=left]g)      userForm.jsp,用户表单网页;            [/align]
[align=left]h)      userList.jsp,用户列表网页;[/align]
[align=left]i)        decorators/default.jsp,系统布局控制网页;[/align]
[align=left]j)        scripts下存放系统所需js文件;[/align]
[align=left]k)      images下存放系统所需图片文件;[/align]
[align=left]l)        styles下存放样式表文件;[/align]
[align=left]m)   WEB-INF/web.xml,Web程序描述符文件;[/align]
[align=left]n)      WEB-INF/action-servlet.xml,Spring的控制配置文件;[/align]
[align=left]o)      WEB-INF/applicationContext-jdbc.xml,Spring的JDBC配置文件;[/align]
[align=left]p)      WEB-INF/applicationContext-validation.xml,Spring的客户端检测文件;[/align]
[align=left]q)      WEB-INF/applicationContext.xml,Spring配置文件;[/align]
[align=left]r)        WEB-INF/decorators.xml,程序布局配置文件;[/align]
[align=left]s)      WEB-INF/sitemesh.xml,Sitemesh配置文件;[/align]
[align=left]t)       WEB-INF/validation.xml,客户端检测文件;[/align]
[align=left]u)      WEB-INF/validator-rules.xml,客户端检测规则文件。[/align]
[align=left]v)      WEB-INF/Classes下存放程序编译后的类文件;[/align]
[align=left]w)    WEB-INF/lib下存放程序所需类库,如下:[/align]
[align=left]                                     i.              antlr-2.7.6rc1.jar[/align]
[align=left]                                  ii.              asm-1.5.3.jar[/align]
[align=left]                                iii.              cglib-2.1_3.jar[/align]
[align=left]                                iv.              commons-beanutils-1.7.0.jar[/align]
[align=left]                                   v.              commons-collections-3.1.jar[/align]
[align=left]                                vi.              commons-digester-1.5.jar[/align]
[align=left]                              vii.              commons-lang-2.1.jar[/align]
[align=left]                           viii.              commons-logging-1.0.4.jar[/align]
[align=left]                                ix.              commons-validator-1.1.3.jar[/align]
[align=left]                                   x.              displaytag-1.1.jar[/align]
[align=left]                                xi.              dom4j-1.6.1.jar[/align]
[align=left]                              xii.              dwr-1.0.jar[/align]
[align=left]                           xiii.              ehcache-1.1.jar[/align]
[align=left]                            xiv.              geronimo-spec-jta-1.0.1B-rc4.jar[/align]
[align=left]                              xv.              hibernate-3.1.2.jar[/align]
[align=left]                            xvi.              itext-1.3.jar[/align]
[align=left]                         xvii.              jstl-1.1.2.jar[/align]
[align=left]                       xviii.              log4j-1.2.11.jar[/align]
[align=left]                            xix.              postgresql-8.1-404.jdbc3.jar[/align]
[align=left]                              xx.              sitemesh-2.2.1.jar[/align]
[align=left]                            xxi.              spring-1.2.6.jar[/align]
[align=left]                         xxii.              springmodules-validator-0.1.jar[/align]
[align=left]                       xxiii.              standard-1.1.2.jar            [/align]

2.5.1使用sitemesh建立复合视图

[align=left]sitemesh应用Decorator模式,用filter截取request和response,把页面组件head,content,banner结合为一个完整的视图。大多数时候,开发人员都是采用JSP提供的include标签在每个jsp页面包含各种header, stylesheet, scripts and footer,繁琐而不容易维护。sitemesh的出现,让开发人员更方便、更快捷建立系统的复合视图。[J1] [/align]

2.5.1.1 Sitemesh简介

    Sitemesh是由一个基于Web页面布局、装饰以及与现存Web应用整合的框架。它能帮助我们在由大量页面构成的项目中创建一致的页面布局和外观,如一致的导航条,一致的banner,一致的版权,等等。它不仅仅能处理动态的内容,如jspphpasp等产生的内容,它也能处理静态的内容,如htm的内容,使得它的内容也符合你的页面结构的要求。甚至于它能将HTML文件象include那样将该文件作为一个面板的形式嵌入到别的文件中去。所有的这些,都是GOF的Decorator模式的最生动的实现。尽管它是由java语言来实现的,但它能与其他Web应用很好地集成。

2.5.1.2与Strust Tiles比较

[align=left]  从使用角度来看,Tiles似乎是Sitemesh标签<page:applyDecorator>的一个翻版。其实sitemesh最强的一个特性是sitemesh将decorator模式用在过滤器上。任何需要被装饰的页面都不知道它要被谁装饰,所以它就可以用来装璜来自phpaspCGI等产生的页面了。你可以定义若干个装饰器,根据参数动态地选择装饰器,产生动态的外观以满足你的需求。它也有一套功能强大的属性体系,它能帮助你构建功能强大而灵活的装饰器。相比较而言,在这方面Tiles就逊色许多。[/align]

2.5.1.3基本原理

[align=left]   一个请求到服务器后,如果该请求需要sitemesh装饰,服务器先解释被请求的资源,然后根据配置文件获得用于该请求的装饰器,最后用装饰器装饰被请求资源,将结果一同返回给客户端浏览器。[/align]

2.5.1.4 sitemesh的filter配置

[align=left]为读者简单介绍了sitemesh的相关内容,下面进行相关配置的讲解。[/align]
[align=left]首先,在WEB-INF/web.xml中加入以下filter的定义,代码例如清单2-1所示:[/align]
[align=left]清单2-1 web.xml中sitemesh的filter配置[/align]
[align=left]<filter>[/align]
[align=left]       <filter-name>sitemesh</filter-name>[/align]
[align=left]       <filter-class>[/align]
[align=left]           com.opensymphony.module.sitemesh.filter.PageFilter[/align]
[align=left]       </filter-class>[/align]
[align=left]    </filter>[/align]
[align=left]<filter-mapping>[/align]
[align=left]       <filter-name>sitemesh</filter-name>[/align]
[align=left]       <url-pattern>/*</url-pattern>[/align]
[align=left]       <dispatcher>REQUEST</dispatcher>[/align]
[align=left]       <dispatcher>FORWARD</dispatcher>[/align]
[align=left]    </filter-mapping>[/align]
[align=left]上述代码配置了sitemesh的过滤类com.opensymphony.module.sitemesh.filter.PageFilter,同时定义了REQUEST、FORWARD的分发。[/align]

2.5.1.5 支持sitemesh运行所需文件

[align=left]读者访问http://www.opensymphony.com/sitemesh/download.action,下载sitemesh的最新版本2.2.1,将sitemesh-2.2.1.jar复制到jdbc/WebContent/WEB-INF/lib即可。[/align]
[align=left]注意:读者只需下载sitemesh的sitemesh-2.2.1.jar即可。[/align]

2.5.1.6 装饰器配置decorators.xml

[align=left]建立WEB-INF/decorators.xml描述各装饰器页面,代码例如2-2清单:[/align]
[align=left]清单2-2 HibernateUtil.java[/align]
[align=left]<decorators defaultdir="/decorators">[/align]
[align=left]    <decorator name="default" page="default.jsp">[/align]
[align=left]        <pattern>/*</pattern>[/align]
[align=left]    </decorator>[/align]
[align=left]</decorators>[/align]
[align=left]这里定义了缺省的目录装饰器页面目录decorators,定义了装饰器网页default.jsp。[/align]

2.5.1.7 sitemesh.xml配置文件的实现

[align=left]sitemesh.xml为sitemesh的核心配置文件,代码例如清单2-3所示:[/align]
[align=left]清单2-3 sitemesh.xml[/align]
[align=left]<sitemesh>[/align]
[align=left]    <property name="decorators-file" value="/WEB-INF/decorators.xml"/>[/align]
[align=left]    <excludes file="${decorators-file}"/>[/align]
[align=left]    <page-parsers>[/align]
[align=left]        <parser default="true" [/align]
[align=left]            class="com.opensymphony.module.sitemesh.parser.HTMLPageParser"/>[/align]
[align=left]        <parser content-type="text/html" [/align]
[align=left]            class="com.opensymphony.module.sitemesh.parser.HTMLPageParser"/>[/align]
[align=left]        <parser content-type="text/html;charset=ISO-8859-1"[/align]
[align=left]            class="com.opensymphony.module.sitemesh.parser.HTMLPageParser"/>[/align]
[align=left]    </page-parsers>[/align]
[align=left] [/align]
[align=left]    <decorator-mappers>[/align]
[align=left]        <mapper class="com.opensymphony.module.sitemesh.mapper.ConfigDecoratorMapper">[/align]
[align=left]            <param name="config" value="${decorators-file}"/>[/align]
[align=left]        </mapper>[/align]
[align=left]    </decorator-mappers>[/align]
[align=left]</sitemesh>[/align]
[align=left]sitemesh.xml定义了以下内容:[/align]
[align=left]1.      装饰器文件,如:decorators-file,值为/WEB-INF/decorators.xml;[/align]
[align=left]2.      页面解析,如:page-parsers,包括:[/align]
[align=left]a)      default="true",缺省为true,表示所有页面都解析,指向的类为com.opensymphony.module.sitemesh.parser.HTMLPageParser;[/align]
[align=left]b)      content-type="text/html",表示content-type为text/html,指向的类为com.opensymphony.module.sitemesh.parser.HTMLPageParser;[/align]
[align=left]c)       content-type="text/html;charset=ISO-8859-1",表示content-type为text/html,同时指定charset为ISO-8859-1,指向的类为com.opensymphony.module.sitemesh.parser.HTMLPageParser。[/align]
[align=left]3.      缺省装饰器映射,如:decorator-mappers,映射类为com.opensymphony.module.sitemesh.mapper.ConfigDecoratorMapper,参数为${decorators-file},也就是/WEB-INF/decorators.xml。[/align]
注意:关于sitemesh的配置,上面内容读者完全可以照做,根据实际需要,修改default.jsp的布局即可。

 [J1]这张图需要替换,其中servlet-api.jar不需要
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
相关文章推荐