STRUTS2实验报告
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
1. 系统分析与设计 1.1 系统功能描述
本系统是个非常简单的注册、登录系统。本系统的实现是基于struts2、spring、
hibernate三个框架,系统功能单一,业务逻辑简单。
当用户注册信用户时,就是向系统中增加一个新用户,对应的数据库增加一条记录。
当用户输入注册信息时,系统提供了基本的输入验证判断用户输入是否合法,只有当用
户输入满足基本输入要求时,才会被提交到实际的登录系统,进行实际的登录处理。
系统还使用了随机产生的图形验证码来防止刷新,防止用户通过单击浏览器的书安心按
钮来重复注册多个用户。
系统还提供了一种ajax方式来验证用户输入的注册名是否有效,系统要求所有的用户名
不能重复。故当用户输完用户名后,系统立即在页面上方提示用户该用户名是否可用,如果
系统中没有该用户名,则系统提示该用户名可用;否则提示用户该用户名重复,用户必须重
新选择用户名注册。
当用户注册一个新用户名之后,就可以使用系统的登录功能来登录系统了,用户输入登
录用的用户名、密码后,系统一样提供了基本的输入校验。
除此之外,系统还采用了随机产生图形验证码来防止恶意用户的暴力破解,系统随机生
成一个图形验证码,而用户登录必须输入图形验证码中显示的字符串,只有用户输入的字符
串和系统随机生成的验证码字符相同时,系统才允许用户登录。
1.2 系统功能流程
1.3 数据库设计
相关的映射文件:
<hibernate-mappingpackage= <classname=user table=user_table> <id name=idcolumn=user_id> <generatorclass=identity</id> nique=true/>
<propertyname==user_passnot-null=true length=50/> <propertyname=emaillength=100/> </class> <propertyname=usercolumn=</hibernate-mapping>
一旦提供了上面的映射文件,hibernate就可以理解user和user_table之间的对应关
系。
2.系统实现与测试 2.1 系统采用的关键技术
mvc框架采用了struts2框架,struts2框架的易用性,极好的简化了系统的mvc层的实
现;本系统使用了struts2的json插件来完成ajax功能,除此之外本系统为了避免进行底
层的ajax交互,还是用了一个简单prototype.js函数库,用以简化ajax编程。struts2框
架的稳定性,为系统的稳定运行提供了保证。
spring容器作为系统的ioc容器,将系统中所有组件都放在spring容器中进行管理,
并且充分利用了spring ioc容器的功能,采用依赖注入来管理系统中各组件的依赖关系,避
免了各组件之间的硬编码耦合,提高了系统的可扩展性。
借助hibernate orm框架实现系统的持久化,通过hibernate的框架帮助,允许上层程
序采用面向对象的方式编程,二hibernate负责把面向对象的持久化操作转换成jdbc操作,
但hibernate的底层操作对开发者完全透明,从而让用户从具体的jdbc访问中释放出来,无
需理会底层的jdbc数据库访问,而是以面向对象的方式进行持久化操作。
2.2 关键程序流程
以注册为例说明:
加载类(filterdispatcher)
读取配置(struts配置文件中的regist.action) ? 派发请求(客户端发送请求)
调用action(filterdispatcher从struts配置文件中读取与之相对应的action ) ?
启用拦截器(webwork拦截器链自动对请求应用通用功能) ? 处理业务(回调registaction
的execute()方法)
返回响应(通过execute方法将信息返回到filterdispatcher)
查找响应(filterdispatcher根据配置查找响应的是什么信息如:success、
erroer,将跳转到哪个jsp页面) ? 响应用户(jsp--->客户浏览器端显示)
2.3 关键代码分析
regist.action的execute方法
publicstring execute() throws exception{ map session = actioncontext. ().getsession(); session.put(rand , null); string ver2 = (string )session.get(rand); if (mgr }
returnreturn}else{
if (vercode.equals(ver2)) { } else{ addactionerror(验证码不匹配,请重新输入); }returnfailure; } 业务逻辑层:
publicint adduser(string user , string pass , string email) }
publicvoidsave(user user){ gethibernatetemplate().save(user); } throws exception{ try{ user u = new user(); u.setuser(user); userdao returne.printstacktrace(); } catch thrownew exception(新增用户时出现异常); } sessionfactory是hibernate的持久化操作的基础对象,是整个数据库经过编辑后的内
存镜像,通常对应一个底层数据库。进行hibernate的持久化操作前,必须先完成
sessionfactory的初始化。
本系统通过spring容器管理sessionfactory,从而允许开发人员无需手动管理
hibernate的sessionfactory。代码如下:
<beanid=sessionfactoryclass=org.springframework.orm.hibernate3.localsessionfa
ctorybean>
<propertyname=datasourceref=datasource/>
<propertyname=mappingresources> <list> <value>user.hbm.xml</value></list> </property> <propertyname=hibernateproperties> <props> > <propkey=show_sql>true</prop>