ImageVerifierCode 换一换
格式:DOCX , 页数:37 ,大小:160.78KB ,
资源ID:6235124      下载积分:12 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/6235124.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(框架模型strutshibernate.docx)为本站会员(b****6)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

框架模型strutshibernate.docx

1、框架模型strutshibernateStruts 2目录Struts 2 概述Struts 2 工作原理Struts技术的发展概况Struts的体系结构Struts2和Struts1的对比WebWork和Struts2的对比Struts2中的ActionSupport基类展开Struts 2 概述Struts 2 工作原理Struts技术的发展概况Struts的体系结构Struts2和Struts1的对比WebWork和Struts2的对比Struts2中的ActionSupport基类展开编辑本段Struts 2 概述Struts 2是Struts的下一代产品,是在 struts 1和We

2、bWork的技术基础上进行了合并的全新的Struts 2框架。其全新的Struts 2的体系结构与Struts 1的体系结构差别巨大。Struts 2以WebWork为核心,采用拦截器的机制来处理用户的请求,这样的设计也使得业务逻辑控制器能够与Servlet API完全脱离开,所以Struts 2可以理解为WebWork的更新产品。虽然从Struts 1到Struts 2有着太大的变化,但是相对于WebWork,Struts 2的变化很小。编辑本段Struts 2 工作原理工作原理(2张)编辑本段Struts技术的发展概况 经过六年多的发展,Struts1已经成为了一个高度成熟的框架,不管是稳

3、定性还是可靠性都得到了广泛的证明。市场占有率超过20%,拥有丰富的开发人 群,几乎已经成为了事实上的工业标准。但是随着时间的流逝,技术的进步,Struts1的局限性也越来越多地暴露出来,并且制约了Struts1的继续发 展。 对于Struts1框架而言,由于与JSP/Servlet耦合非常紧密,因而导致了一些严重 的问题。首先,Struts1支持的表现层技术单一。由于Struts1出现的年代比较早,那个时候没有FreeMarker、Velocity等技术, 因此它不可能与这些视图层的模版技术进行整合。其次,Struts1与Servlet API的严重耦合,使应用难于测试。最后,Struts1代

4、码严重依赖于Struts1 API,属于侵入性框架。 从目前的技术层面上看,出现了许多与Struts1竞争的视图层框架,比如JSF、 Tapestry和Spring MVC等。这些框架由于出现的年代比较近,应用了最新的设计理念,同时也从Struts1中吸取了经验,克服了很多不足。这些框架的出现也促进了 Struts的发展。目前,Struts已经分化成了两个框架:第一个是在传统的Struts1的基础上,融合了另外的一个优秀的Web框架 WebWork的Struts2。Struts2虽然是在Struts1的基础上发展起来的,但是实质上是以WebWork为核心的。Struts2为传 统的Struts

5、1注入了WebWork的先进的设计理念,统一了Struts1和WebWork两个框架。Struts1分化出来的另外一个框架是 Shale。这个框架远远超出了Struts1原有的设计思想,与原有的Struts1关联很少,使用了全新的设计思想。Shale更像一个新的框架而不 是Struts1的升级。 本文下面的内容将主要讨论Struts2。编辑本段Struts的体系结构Struts2应用流程注解当Web容器收到 请求(HttpServletRequest)它将请求传递给一个标准的的过滤链包括流程(ActionContextCleanUp)过滤器,然后进过Other filters(SiteMesh

6、 ,etc), 接下来需要调用FilterDispatcher核心控制器,然后它调用ActionMapper确定请求那个Action,ActionMapper返回一个收集Action详细信息的ActionMaping对象。 接下来FilterDispatcher将控制权委派给 ActionProxy,ActionProxy调用配置管理器(ConfigurationManager) 从配置文件中读取配置信息(struts.xml),然后创建ActionInvocation对象,ActionInvocation在调用 Action之前会依次的调用所用配置拦截器(Interceptor N) 一旦执

7、行结果返回结果字符串ActionInvocation负责查找结果字符串对应的(Result)然后执行这个Result Result会调用一些模版(JSP) 来呈现页面,之后拦截器(Interceptor N)会在被执行(顺序和Action执行之前相反)最后响应(HttpServletResponse)被返回在web.xml中配置的那些过滤器和(核心控制器)(FilterDispatcher)。编辑本段Struts2和Struts1的对比通过上面对Struts2体系结构的了解,我们发现Struts2对Struts1进行了巨大的改进。主要表现在如下几个方面: 在Action的实现方面:Struts

8、1要求必须统一扩展自Action类,而Struts2中可以是一个普通的POJO。 线程模型方面:Struts1的Action工作在单例模式,一个Action的实例处理所有的请求。Struts2的Action是一个请求对应一个实例(每次请求时都新new出一个对象)。没有线程安全方面的问题。 Servlet依赖方面:Struts1的Action依赖于Servlet API,比如Action的execute方法的参数就包括request和response对象。这使程序难于测试。Struts2中的Action不 再依赖于Servlet API,有利于测试,并且实现TDD。 封装请求参数:Struts1

9、中强制使用ActionForm对象封装请求的参数。Struts2可以选择使用POJO类来封装请求的参数,或者直接使用Action的属性。 表达式语言方面:Struts1中整合了EL,但是EL对集合和索引的支持不强,Struts2整合了OGNL(Object Graph NavigationLanguage)。 绑定值到视图技术:Struts1使用标准的JSP,Struts2使用“ValueStack”技术。 类型转换:Struts1中的ActionForm基本使用String类型的属性。Struts2中使用OGNL进行转换,可以更方便的使用。 数据校验:Struts1中支持覆盖validate

10、方法或者使用Validator框架。Struts2支持重写validate方法或者使用XWork的验证框架。 Action执行控制的对比:Struts1支持每一个模块对应一个请求处理,但是模块中的所有Action必须共享相同的生命周期。Struts2支持通过拦截器堆栈为每一个Action创建不同的生命周期。编辑本段WebWork和Struts2的对比 Struts和Webwork同为服务于Web的一种MVC框架,从某种程度上看,Struts2是从WebWork2上升级得到的。甚至Apache 的官方文档也讲:WebWork2到Struts2是平滑的过渡。我们甚至也可以说Struts2就是Web

11、Work2.3而已。在很多方面Struts 仅仅是改变了WebWork下的名称。Struts2对应的有自己的标签,并且功能强大。Webwork也有自己的标签。在2005年12 月,WebWork与Struts Ti决定合并, 再此同时, Struts Ti 改名为 Struts Action Framework 2.0,成为Struts真正的下一代。编辑本段Struts2中的ActionSupport基类ActionSupport基类中定义的五个标准返回值ActionSupport基类中定义了五个标准的返回值 ,当然我们可以自己随意定义返回的名字 String SUCCESS = succes

12、s; /默认是 SUCCESS 类型 String NONE = none; String ERROR = error; String INPUT = input; String LOGIN = login;ActionSupport基类中的方法ActionSupport基类定义了了一些方法,程序员自己写的action如果继承了ActionSupport基类,就可以应用这些方法,很方便解决一些问题。 一些比较常用的方法: getText(String aTextName);/国际化用到 ./getText(String aTextName)的重载方法 addActionMessage(Stri

13、ng aMessage); addFieldError(String fieldName, String errorMessage); /校验失败后返回给客户端的信息,struts2 标签可以取得 addActionError(String anErrorMessage);编辑本段Result Type在默认时,标签的type属性值是“dispatcher”(实际上就是转发,forward)。开发人员可以根据自己的需要指定不同的类型,如redirect、stream等。如下面代码所示: /result.jsp 这此result-type可以在struts2-core-2.0.11.1.jar包

14、或struts2源代码中的struts-default.xml文件中找到,在这个文件中找到标签,所有的result-type都在里面定义了。代码如下: dispatcher用来转向页面,通常处理JSP org.apache.struts2.dispatcher.ServletDispatcherResultfreemaker处理FreeMarker模板 org.apache.struts2.views.freemarker.FreemarkerResulthttpheader控制特殊HTTP行为的结果类型 org.apache.struts2.dispatcher.HttpHeaderResu

15、ltstream向浏览器发送InputStream对象,通常用来处理文件下载,还可用于返回AJAX数据 org.apache.struts2.dispatcher.StreamResult StreamResult等价于在Servlet中直接输出Stream流。这种Result被经常使用于输出图片、文档等二进制流到 客户端。通过使用StreamResult,我们只需要在Action中准备好需要输出的InputStream即可。 配置: image/jpeg imageStream filename=document.pdf 1024 同时,StreamResult支持许多参数,对输出的Stre

16、am流进行参数控制。velocity处理Velocity模板 org.apache.struts2.dispatcher.VelocityResult 随着模板技术的越来越流行,使用Freemarker或者Velocity模板进行View层 展示的开发者越来越多。Struts2同样为模板作为Result做出了支持。由于模板的显示需要模板(Template)与数据(Model)的紧密配 合,所以在Struts2中,这两个Result的主要工作是为模板准备数据。xslt处理XML/XLST模板 org.apache.struts2.views.xslt.XSLTResultplainText显示原

17、始文件内容,例如文件源代码 org.apache.struts2.dispatcher.PlainTextResultchain用来处理Action链 com.opensymphony.xwork2.ActionChainResult chain其实只是在一个action执行完毕之后,forward到另外一个action, 所以他们之间是共享HttpServletRequest的。在使用chain作为Result时,往往会配合使用 ChainingInterceptor。ChainingInterceptor的作用是在Action直接传递数据。事实上,源Action中 ValueStack的数

18、据会被做一次Copy,这样,2个Action中的数据都在ValueStack中,使得对于前台来说,通过 ValueStack来取数据,是透明而共享的。比如说,一张页面中,你可能有许多数据要显示,而某些数据的获取方式可能被很多不同的页面共享(典型来 说,“推荐文章”这个小栏目的数据获取,可能会被很多页面所共享)。这种情况下,可以把这部分逻辑抽取到一个独立Action中,并使用chain,将这 个Action与主Action串联起来。这样,最后到达页面的时候,页面始终可以得到每个Action中的数据。 从实战上讲,使用chain作为Result也的确存在着上面所说的许多问题,我个人也是非常 不推崇

19、滥用这种Result。尤其是,对于使用Spring和Hibernate的朋友来说,如果你开启OpenSessionInView模式,那么 Hibernate的session是跟随HttpServletRequest的,所以session在整个action链中共享。这会为我们的编程带 来极大的麻烦。因为我们知道Hibernate的session会保留一份一级缓存,在action链中,共享一级缓存无疑会为你的调试工作带来很大的不 方便。 所以,谨慎使用chain作为你的Result,应该成为一条最佳实践。redirect重定向到一个URL org.apache.struts2.dispatcher

20、.ServletRedirectResult 如果你在Action执行完毕后,希望执行另一个Action,有2种方式可供选择。一种是 forward,另外一种是redirect。有关forward和redirect的区别,这里我就不再展开,这应该属于Java程序员的基本知识。在 Struts2中,分别对应这两种方式的Result,就是chain和redirect。 先来谈谈redirect,既然是重定向,那么源地址与目标地址之间是2个不同的HttpServletRequest。所以目标地址将无法通过ValueStack等Struts2的特性来获取源Action中的数据。 同时,Redirect

21、的Result支持在配置文件中,读取并解析源Action中ValueStack的值,并成为参数传递到Redirect的地址中。redirectAction重定向到一个Action org.apache.struts2.dispatcher.ServletActionRedirectResultredirect-action重定向到一个Action org.apache.struts2.dispatcher.ServletActionRedirectResult编辑本段区别redirect和redirectAction chain的区别 struts2中关于result的返回类型一般我们是转发到

22、一个jsp页面或者是html页 面等,但是struts2中的result的返回类型还有redirect,redirectAction,chain。对于这三种返回类型之间肯定是有 区别的,下面我们来看看关于redirect redirectAction chain这三种struts2的返回类型之间的区别。当使用type=“redirectAction” 或type=“redirect”提交到一个action并且需要传递一个参数时。这里是有区别的:使用type=“redirectAction”时, 结果就只能写Action的配置名,不能带有后缀:“.action” Xml代码 User?u_id=

23、$loginBean.u_id User?u_id=$loginBean.u_id 使用type=“redirect”时,结果应是action配置名+后缀名 Xml代码 User.action?u_id=$loginBean.u_id redirect:action处理完后重定向到一个视图资源(如:jsp页面),请求参数全部丢失,action处理结果也全部丢失。 redirect-action:action处理完后重定向到一个action,请求参数全部丢失,action处理结果也全部丢失。 chain:action处理完后转发到一个action,请求参数全部丢失,action处理结果不会丢失。

24、mvc百科名片MVC三层架构MVC是 模型(Model),视图(View)和控制(Controller)的缩写,其目的实现Web系统的职能分工。其中Model层实现系统中的业务逻辑, 通常可以用JavaBean或EJB来实现; View层用于与用户的交互,通常用JSP来实现; Controller层是Model与View之间沟通的桥梁,它可以分派用户的请求并选择恰当的视图以用于显示,同时它也可以解释用户的输入并将它们映 射为模型层可执行的操作。 查看精彩图册外文名:mvc 全名:Model View Controller 产生时间:1982年 架构内容:视图,模型,控制器 类别:一种设计模式 目录简介设计模式设计模式框架类别优缺点展开简介设计模式设计模式框架类别优缺点展开编辑本段简介MVC全名是Model View Controller,是模型(model)视图(view)控制器(controller)的缩写,一种软件设计典范,用于组织代码用一种业务逻辑和数据显示分离的方法,这个方法的假设前提是如果业务逻辑被聚集到一个部件里面,而且界面和用户围绕数据的交互能被改进和个性化定制而不需要重新编写业务逻辑MVC被独特的发展起来用于映射传统的输入、处理和输出功能在一个逻辑的图形化用户界面的结构中。1 MVC开始是存在于Desktop程序中的,M是指数据模型

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1