MVC架构在Web应用系统的应用-设计应用_第1页
MVC架构在Web应用系统的应用-设计应用_第2页
MVC架构在Web应用系统的应用-设计应用_第3页
MVC架构在Web应用系统的应用-设计应用_第4页
MVC架构在Web应用系统的应用-设计应用_第5页
已阅读5页,还剩7页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

精品文档-下载后可编辑MVC架构在Web应用系统的应用-设计应用

和C/S结构相比,B/S结构受限于网络带宽不利于进行大数据量的统计分析,网络传输存在潜在的安全问题,还有用户界面不及C/S结构友好等等,但随着网络带宽和网络应用的发展,加上AJAX技术的流行,使得现在越来越多的MIS系统或基于MIS系统的化应用系统都开始倾向于采用B/S结构进行设计,充分利用B/S结构的优点。但是,要充分发挥Web应用的内在潜力,挖掘应用深度和扩大适应能力,需要采用先进的应用架构和以实用为根本准则,使得系统既能满足业务需求,又能适应将来发展需要。因此,在开发Web应用系统时需要尽量遵循Web应用系统设计原则。

1MVC描述的软件模型

MVC是三个单词的缩写,分别为:模型(Model),视图(View)和控制Controller)。MVC模式的目的就是实现Web系统的职能分工。Model层实现系统中的业务逻辑,通常可以用JavaBean或EJB来实现。View层用于与用户的交互,通常用JSP来实现。Controller层是Model与View之间沟通的桥梁,它可以分派用户的请求并选择恰当的视图以用于显示,同时它也可以解释用户的输入并将它们映射为模型层可执行的操作。这三层结构之间的关系如图1所示。

模型层(也称业务层)用于处理程序逻辑。它的任务是管理应用程序域的行为和数据,响应来自控制层的状态指令,把原有数据按照业务逻辑转换成指定意义的数据提供给视图层显示。

视图层用于把表示模型数据、逻辑关系和状态的信息以特定的形式表现在用户界面上。视图层的显示信息来自模型层,同一个模型可以对应多个视图。

控制层用于处理用户与软件的交互操作。控制层通知模型和视图做出相应的状态改变,使模型和视图协调工作。

2MVC模式设计

模型表示企业数据和业务规则。在MVC的三个部件中,模型拥有多的处理任务。例如它可能用象EJBs和ColdFusionComponents这样的构件对象来处理数据库。被模型返回的数据是中立的,就是说模型与数据格式无关,这样一个模型能为多个视图提供数据。由于应用于模型的代码只需写就可以被多个视图重用,所以减少了代码的重复性。MVC模式把界面表现和逻辑控制语句强制分离,解决了页面设计和程序开发中的工作交错与冲突,并解决了由于商业逻辑嵌入造成程序不可重用而且很难维护的问题。

本文设计了一个基于PHP语言、XML和XSL模板技术的MVC架构的Web应用系统。

2.1代码结构

在系统中每一个页面被定义为一个Action,控制器中定义了每一个Action对应的模型和视图,它们之间的对应关系如图2所示。

表1为系统的基础代码结构,除少量的静态页面放在htdocs目录下外,其余的程序都放在PHP的库文件目录下。

在这个代码结构中,模型、视图和控制器三部分分别放置在不同目录中。其中,视图层包括显示模板(XSL)和页面操作控制(JS)二部分,模型层包括业务逻辑处理类库(ActionClass)、数据输出处理(ActionExecute)和PHP基础类库(PHPClass)三部分。因此,在系统中各部分的开发由不同的角色来完成,角色之间的工作交错和冲突可以减少,使系统程序升级和维护的思路也更加明晰。

2.2系统实现

在系统中,客户端浏览器中呈现的是系统的视图部分,而模型和控制器则是透明的。当Web服务器接收到客户提交的HTTP请求后,交给服务器中的控制器来处理。控制器按照请求中的Action信息,从系统配置中提取此Action的映射表,并把此请求映射到相应的处理模型;处理模型进行业务逻辑处理,处理完后返回状态更新的请求并将XML格式的数据结果给控制器;控制器根据结果选择相应视图模板并合成视图返回给客户。程序架构如图3所示。

2.2.1控制层的实现

在这个系统中,控制器主要有以下四个作用。

(1)根据Action名称从数据库的映射表中找到处理此Action的模型信息、视图模板和此视图的用户操作控制信息。

(2)调用模型处理Action请求。

(3)合成业务逻辑处理返回的XML格式的数据信息和XSL视图模板为HTML的文件,并返回给客户端。

(4)在接收到一个业务逻辑处理模型返回的状态更新请求后,调用一个新的业务逻辑处理模型处理此请求。

控制器主要包括二个文件:includes/prepend.inc和includes/controller/controller.inc.prepend.inc文件被设定为自动增加在被访问的文件前,因此这个文件非常适合作为控制器的主文件;Controller.inc中主要是控制器中的处理函数。这二个文件的代码如下。

prepend.inc

?

include_once(″/action/configure/db.conf″);//数据库连接对象

include_once(″/control/controller.inc″);//控制器

$actionobj=getaction($action);//获得Action信息

if($actionobj[″model″]!=″″){

//调用model处理action请求信息

include_once($actionobj[″model″]);

eval(″\$modelobj=execute_″。$actionobj[″action″].″();″);

if($modelobj[″type″]==″xmldata″){//返回html

//输出xml和xsl合成的html数据

echoxmlpraser($modelobj[″data″],$actionobj[″view″]);

}elseif($modelobj[″type″]==″state″){//请求更新状态

header(″Location:?″。$modelobj[″data″]);//交新模型处理

exit;

}

}else{//直接调用View输出}

?

controller.inc:

?

****得actionobj的信息****

functiongetaction($action){

global$dbobj,$conn,$result_id;//数据对象,连接,结果集

//从数据库中检索action对象信息

$sqlstr=″select*fromt_actionwhereaction=′″。$action.″′″;

$result_id=$dbobj-exec($conn,$sqlstr);

if($dbobj-fetch_row($result_id)){

$actobj[″action″]=$action;

//action的处理模型名称

$actobj[″model″]=$dbobj-result($result_id,″model″);

//action的视图模板信息

$actobj[″view″]=$dbobj-result($result_id,″template″);

//其他控制参数

}else{…}

return$actobj;

}

//****解析xml和xslt****

functionphp_scheme_get_all($Processor,$Schema,$RestUri){

$url=$Schema.′:′。$RestUri;

returnfile_get_contents($url);

}

functionxmlpraser($data,$xslpath){

global$SYS_INCLUDEPATH;

$parser=xslt_create();//初始化解析对象

xslt_set_scheme_handlers($parser,array(′get_all′=

′php_sheme_get_all′));//设置处理方式

$parms[″_xml″]=″?xmlversion=\″1.0\″encoding=\″gb2312\

″?″.$data;//合成xml格式数据

$parms[″_xsl″]=file_get_contents($SYS_INCLUDEPATH.

″\\″.$xslpath);//读取xsl模板文件

$result.=xslt_process($parser,′arg:/_xml′,′arg:/_xsl′,

NULL,$parms);//合成视图

xslt_free($parser);//释放解析对象

return$result;

}

?

2.2.2模型层的实现

模型是系统的数据。此系统中模型层主要包括三部分内容。

(1)业务逻辑处理。业务逻辑处理又可以分为二类:一类是抽象出来的业务逻辑,被封装成一个个PHP类;另一类是对某一具体Action的逻辑处理。

(2)PHP的基础类库。此部分与业务逻辑无关,描述的是对任何一类的应用系统中都要使用的公共函数类,这些类可以被其他程序调用。

(3)数据输出处理,把PHP数据转换成XML格式输出。

按照控制器的定义,每一个Actionname都要调用一个命名为execute_actionname()的函数,这个函数会返回Action的处理结果。处理结果有二种情况:一种是返回XML格式的数据;一种是返回要求系统更新状态的状态值。一个典型的模型处理器程序结构如下:

include_once(″/action/tool/tools.inc″);//工具系统的基础类

functiongettoollist($toolid){//获得工具信息

//指定要获得的工具信息

$params=array(″toolname″,″part_no″,″quantity″);

$toolobj=newtoolinfo;//创建toolinfo类实例

$toolstinfo=$toolobj-GetToolListinfo($toolid,$params);

return$toolsinfo;//返回工具列表信息

}

functiongetxml($toolsinfo){//转换工具信息为xml格式

while(list($id,$toolarray)=each($toolsinfo[″data″])){

$xmlstr.=″items″;

while(list($key,$value)=each($toolarray)){

$xmlstr.=″″.$key.″″。$value.″/″。$key.″″;

}

$xmlstr.=″/items″;

}

return$xmlstr;

}

functionexecute_tool_toollist(){//工具列表action的处理函数

$toolinfo=gettoollist($toolid);//工具信息

if($toolinfo[″state″]){//输出xml格式数据

$rtnobj[″type″]=″xmldata″;

$rtnobj[″data″]=getxml(($toolinfo);

}else{//跳转到错误处理页面

$rtnobj[″type″]=″state″;

$rtnobj[″data″]=″errorhandle″;

}

return$rtnobj;

}

?

2.2.3视图层的实现

视图是一个虚拟表,其内容由查询定义。同真实的表一样,视图包含一系列带有名称的列和行数据。但是,视图并不在数据库中以存储的数据值集形式存在。行和列数据来自由定义视图的查询所引用的表,并且在引用视图时动态生成。对其中所引用的基础表来说,视图的作用类似于筛选。定义视图的筛选可以来自当前或其它数据库的一个或多个表,或者其它视图。分布式查询也可用于定义使用多个异类源数据的视图。此系统即使用了XSL模板技术。系统中的视图层包括二部分:一部分是放在/includes/template目录下的XSL模板;另一部分是放在/htdocs目录下的js和css文件。,由控制器来完成合成视图的任务。

2.3系统适应性

从整个系统的设计结构可以看出,系统的业务逻辑和显示是分离的:首先由网页设计人员和程序员共同确定需要的数据项和

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论