Struts简单介绍

一、在介绍struts之前,先来了解一下什么是MVC框架吧。

1、MVC介绍

MVC全名是Model View Controller。是模型(model)-视图(view)-控制器(controller)的缩写,一种软件设计典范。用一种业务逻辑、数据、界面显示分离的方法组织代码。将业务逻辑聚集到一个部件里面,在改进和个性化定制界面及用户交互的同一时候。不须要又一次编写业务逻辑。

当中三层各自的功能:

Model(模型)是应用程序中用于处理应用程序数据逻辑的部分。

  通常模型对象负责在数据库中存取数据。

View(视图)是应用程序中处理数据显示的部分。

  通常视图是根据模型数据创建的。

Controller(控制器)是应用程序中处理用户交互的部分。

  通常控制器负责从视图读取数据。控制用户输入,并向模型发送数据。

MVC 分层同一时候也简化了分组开发。

不同的开发者可同一时候开发视图、控制器逻辑和业务逻辑。

2、struts介绍

Struts是MVC架构,使用Struts的目的是为了帮助我们降低在运用MVC设计模型来开发Web应用的时间。假设我们想混合使用Servlets和JSP的长处来建立可扩展的应用,struts是一个不错的选择。

二、  struts执行原理:

结合上面的图,来理解struts的执行原理:

1、初始化。读取配置文件:在Web应用启动时就会载入并初始化ActionServlet。在载入Struts应用程序时,会先载入web.xml中与Struts相关的一些配置參数,找到struts-config.xml文件。然后通过循环来读取此文件和解析里面的内容。并初始化相关对象。

2、用户请求:用户提交表单或调用url向Web应用程序adclass=0&app_id=0&c=news&cf=1001&ch=0&di=8&fv=17&is_app=0&jk=38f8cdd40b779ad&k=%B7%FE%CE%F1%C6%F7&k0=%B7%FE%CE%F1%C6%F7&kdi0=0&luki=2&n=10&p=baidu&q=sayyescpr&rb=0&rs=1&seller_id=1&sid=ad79b740dd8c8f03&ssp2=1&stid=0&t=tpclicked3_hc&tu=u1366390&u=http%3A%2F%2Fblog%2Eknowsky%2Ecom%2F179728%2Ehtm&urlid=0" id="5_nwl" style="text-decoration:none">server提交一个请求, 
首先会到达ActionServlet这个对象中,在此截取发送请求的URI地址。在和第一步中读取出来的配置文件信息相关内容做对照,找到和这个URI地址相匹配的地址。然后确定其要转向的Action。在此过程中。如这个Action有一个对应的ActionForm。则会把表单中提交的一些数据自己主动匹配到ActionForm的一个实例中,并传递到要转向的Action。

3、业务处理:Action一般仅仅包括一个execute()方法,它负责运行对应的业务逻辑。

在Action中获取传递过来的ActionForm中的数据,然后在调用相关业务逻辑。运行完成后返回一个ActionForward对象,控制器通过该ActionForward对象进行转发工作(通常是跳转到JSP页面对结果进行处理)。

4、接收结果:接收Action中处理的结果,在界面给用户显示相关数据。

三、使用struts的有点:

1. 实现MVC模式,结构清晰,使开发人员仅仅关注业务逻辑的实现.

2. 有丰富的tag能够用 ,Struts的标记库(Taglib),如能灵活动用。则能大大提高开发效率

3. 页面导航.页面导航将是今后的一个发展方向,其实,这样做,使系统的脉络更加清晰。通过一个配置文件。就可以把握整个系统各部分之间的联系,这对于后期的维护有着莫大的优点。

4. 提供Exception处理机制 .

5. 数据库链接池管理

6. 支持I18N

时间: 2024-10-08 15:27:37

Struts简单介绍的相关文章

spring的struts简单介绍

之前一段时间学习了springmvc+mybatis+spring框架,突然对之前的struts东西有点陌生, 所以这里简单记录下温故而知新的东西吧. 1.  首先建立一个Dynamic Web Project, 下面是我建立的StrutsDemo项目目录,使用的是maven构建的, 自己又增加了几个文件夹 2. 给出pom.xml文件: <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http

dubbo学习过程、使用经验分享及实现原理简单介绍

一.前言 部门去年年中开始各种改造,第一步是模块服务化,这边初选dubbo试用在一些非重要模块上,慢慢引入到一些稍微重要的功能上,半年时间,学习过程及线上使用遇到的些问题在此总结下. 整理这篇文章差不多花了两天半时间,请尊重劳动成果,如转载请注明出处http://blog.csdn.net/hzzhoushaoyu/article/details/43273099 二.什么是dubbo Dubbo是阿里巴巴提供的开源的SOA服务化治理的技术框架,据说只是剖出来的一部分开源的,但一些基本的需求已经

struts详细介绍

Struts2 1. 目录 1.目录 2.MVC 3.STRUTS2解析 4.标签 5.OGNL 6.国际化 7.类型转换 8.校验 9. 拦截器 10.上传与下载 11.STRUTS2与对JSON的支持 2. MVC 把软件系统分为三个基本部分:模型(Model).视图(View)和控制器(Controller).MVC模式最早由Trygve Reenskaug在1978年提出,在20世纪80年代为程序语言Smalltalk发明的一种软件设计模式.MVC模式的目的是实现一种动态的程式设计,使后

【dubbo基础】dubbo学习过程、使用经验分享及实现原理简单介绍

一.前言 部门去年年中开始各种改造,第一步是模块服务化,这边初选dubbo试用在一些非重要模块上,慢慢引入到一些稍微重要的功能上,半年时间,学习过程及线上使用遇到的些问题在此总结下. 整理这篇文章差不多花了两天半时间,请尊重劳动成果,如转载请注明出处http://blog.csdn.NET/hzzhoushaoyu/article/details/43273099 二.什么是dubbo Dubbo是阿里巴巴提供的开源的SOA服务化治理的技术框架,据说只是剖出来的一部分开源的,但一些基本的需求已经

【web开发学习笔记】Structs2 Result学习笔记(一)简单介绍

Structs2 Result学习笔记(一)简单介绍 问题一 <struts> <constant name="struts.devMode" value="true" /> <package name="resultTypes" namespace="/r" extends="struts-default"> <action name="r1"

python的列表,元组和字典简单介绍

引 入 java                                   python 存取多个值:数组或list集合 ------------------------> 列表,元组 key-value格式:    Map        ------------------------>    字典 自己学习发现,java跟python这两门面向对象语言在数据类型的定义上,很多思想都是互通的,这里不说java,简单介绍一下python的列表,元组和字典. 一.列表 List: 最通

javascript的return语句简单介绍

javascript的return语句简单介绍:return语句在js中非常的重要,不仅仅具有返回函数值的功能,还具有一些特殊的用法,有个清晰的把握是非常有必要的.下面就结合实例简单介绍一下return语句的作用.一.用来返回控制和函数结果:通常情况,return语句对于一个函数是很有必要的,因为往往需要函数在一系列的代码执行后会得到一个期望的返回值,而此值就是通过return语句返回,并且将控制权返回给主调函数.语法格式: return 表达式 代码实例如下: function add(){

Object-c集合的简单介绍

一.简单介绍 NSArray/NSMutableArray NSSet/NSMutableSet NSDictionary/NSMutableDictionary NSArray.NSSet.NSDictionary是不可变的,创建的时候初始化 NSMutableArray.NSMutableSet.NSMutableDictionary是可变的 二.使用介绍 NSArray是有序的数组 NSMutableArray *myArray=[[NSMutableArray alloc] init];

plsql的环境与介绍:环境的搭建和plsql的简单介绍

PLSQL编程 1.环境的搭建 (1)创建一个存储表空间 SQL> conn /as sysdbaConnected. SQL> create tablespace plsql datafile '/u01/oracle/oradata/ORCL/plsql01.dbf' size 1G; Tablespace created. (2)创建PLSQL用户SQL> create user plsql identified by plsql default tablespace plsql;