Javaweb学习笔记--分层设计
在早期的JavaWeb应用中,JSP文件负责处理业务逻辑,控制网页流程并创建HTML页面,JSP文件是一个独立的,能自主完成所有任务的模块,
这带来了一系列问题:
HTML代码和Java程序代码强耦合在一起
内嵌的流程控制逻辑
调试困难
可维护性差
可读性差
为了解决以上问题,SUN公司先后制定了两种设计模式:jspmodel1以及jspmodel2
本质区别:在于负责流程控制的组件不同。
0x01 Model1
在JSP Model1中,JSP页面负责调用模型组件来响应客户请求,并将处理结果返回给用户。
JSP既要负责流程控制,还要负责产生用户界面,因此它要同时充当视图和控制器的需要,但它不适合开发复杂的大型应用程序。
0x02 MOdel2
JSP Model2用JSP技术实现视图的功能,用Servlet技术实现控制器的功能,用JavaBean实现模型的功能:
Servlet充当控制器的角色,负责处理客户请求,创建JSP页面需要使用的JavaBean对象,并更具客户请求选择合适的JSP页面返回给客户。 在JSP页面内没有流程控制逻辑,它仅负责检索原先由Servlet创建的JavaBean对象,并把JavaBean对象包含的数据作为动态内容插入到静态模板中。 它清晰地分离了数据展示,数据处理和流程控制。
在Model2中,使用一个Servlet或者Filter充当控制器Controller,所有现代的Web框架都是Model2实现。像Struct1和spring MVC这类框架是在他们的MVC架构中使用一个Servlet Controller,而Structs2则使用Filter。 尽管也支持其他的View技术,但一般来说,它用JSP页面作为应用程序的View。至于Model,则是使用POJO对象。许多人选择使用JavaBean保存模型对象的状态,并将业务逻辑转移到一个Action类中。
在Model2应用程序中,每一个HTTP请求都必须被定向到Controller中。请求的URI告诉控制器要调用那一个Action。Action是指应用程序能够执行的一项操作。一个Action类可以用来服务几个不同的Action或单个Action。控制器会仔细查看URI,决定要调用哪一项Action。它还会将模型对象保存在一个可以通过View访问到的地方,以便服务器端的值可以在浏览器中显示出来。最后,控制器用一个RequestDIspatcher跳转到一个View。在View(JSP)页面中,利用EL表达式和定制标签来显示值。
0x03 MVC
目前,javaee体系主要采用的是MVC模式,MVC是模型(model),视图(view)和控制(controller)的缩写。 这种技术是某model2实现的。
MVC主要用于实现web系统的职能分工。
在MVC分层结构中:
model层主要实现系统中的业务逻辑,通常可以用javabean或EJB来实现。
view层主要是用于和用户的交互,主要用jsp来实现。
controller是model和view之间沟通的桥梁,他可以分派用户的请求,并选择恰当的view来实现交互,同时可以解析用户得输入,并将其映射成模型层可以执行的操作。通常用servlet实现。
0x04 什么是三层架构(three-tier application)
通常意义上的三层架构:把整个业务应用分为三层:表现层(UI),业务逻辑层(BLL),数据访问层(DAL)
三层架构的目的:高内聚,低耦合。
表现层(UI):通俗地讲,是展现给用户的东西,也就是用户在使用应用的时候能看到的一切。
业务逻辑层(BLL):根据具体问题的操作,对数据业务进行逻辑的处理
数据访问层:(DAL):直接对数据库进行操作,也就是对数据库进行增删查改等操作。
Javaweb学习笔记--分层设计的更多相关文章
- JavaWeb学习笔记总结 目录篇
JavaWeb学习笔记一: XML解析 JavaWeb学习笔记二 Http协议和Tomcat服务器 JavaWeb学习笔记三 Servlet JavaWeb学习笔记四 request&resp ...
- javaweb学习笔记整理补课
javaweb学习笔记整理补课 * JavaWeb: * 使用Java语言开发基于互联网的项目 * 软件架构: 1. C/S: Client/Server 客户端/服务器端 * 在用户本地有一个客户端 ...
- 【JAVAWEB学习笔记】06_jQuery基础
接05的学习笔记. 四.使用JQ完成省市二级联动 1.需求分析 使用jquery完成省市二级联动 2.技术分析 2.1数组的遍历操作 方式一: $(function(){ // 全选/ 全不选 $(& ...
- javaweb学习笔记(二)
一.javaweb学习是所需要的细节 1.Cookie的注意点 ① Cookie一旦创建,它的名称就不能更改,Cookie的值可以为任意值,创建后允许被修改. ② 关于Cookie中的setMaxAg ...
- Javaweb学习笔记(一)
一.javaweb学习是所需要的细节 1.发送响应头相关的方法 1).addHeader()与setHeader()都是设置HTTP协议的响应头字段,区别是addHeader()方法可以增加同名的响应 ...
- Javaweb学习笔记——(二十一)——————过滤器
过滤器 过滤器概述 1.什么是过滤器: 过滤器javaweb三大组件之一,它与Serlvet很相似,不过它过滤器是用来拦截请求的,而不是处理 ...
- Javaweb学习笔记——(十三)——————JSTL、JSTL核心标签库、自定义标签、有标签体的标签、带有属性的标签、MVC、Javaweb三层框架
JSTLApache提供的标签库 jar包:jstl-1.2.jar,如果传MyEclipse,他会在我们导入jar包,无需自己导入,如果没有使用MyEclipse那么需要自行导入.--------- ...
- JavaWeb学习笔记(七)—— JSP
一.什么是JSP JSP全名是Java Server Pages,它是建立在Servlet规范之上的动态网页开发技术.在JSP文件中,HTML代码与Java代码共同存在,其中,HTML代码用来实现网页 ...
- javaweb学习笔记之servlet01
一.Servlet概述 A servlet is a small Java program that runs within a Web server. Servlets receive and re ...
随机推荐
- 设计Account 对象如下: private long id; private double balance; private String password; 要求完善设计,使得该Account 对象能够自动分配id。 给定一个List 如下:
package homework005; public class Account { private long id; private double balance; private String ...
- Eclipse+Maven构建web项目及部署时Maven lib依赖问题的解决
目录 Eclipse中m2e插件构建web项目的步骤 Maven工具构建web项目再导入Eclipse的步骤 [一].Eclipse中m2e插件构建web项目的步骤 第一步:创建项目,按照 New – ...
- PowerShell远程安装应用程序
安装MSI包 使用PowerShell调用WMI对象,你可以执行下面的脚本来安装你的MSI安装包: $box="deviis01" #this is the name of you ...
- Flex 自动获取焦点 监听全局键盘事件
在mxml里监听addedToStage事件 protected function application1_addedToStageHandler(event:Event):void { this. ...
- SQL 查询横表变竖表
SQL 查询横表变竖表 /*普通行列转换 假设有张学生成绩表(tb)如下:Name Subject Result张三 语文 74张三 数学 83张三 物理 93李四 语文 74李四 数学 84李四 ...
- zookeeper使用场景【转】
分布式网站架构后续:zookeeper技术浅析 Zookeeper是hadoop的一个子项目,虽然源自hadoop,但是我发现zookeeper脱离hadoop的范畴开发分布式框架的运用越来越多. ...
- ios开发——实战OC篇&FMDB详解
FMDB详解 前一篇文章中我们介绍的SQLite的使用,在iOS中原生的SQLite API在使用上相当不友好. 于是,就出现了一系列将SQLite API进行封装的库,例如FMDB.Plausibl ...
- C_数据结构_链表的链式实现
传统的链表不能实现数据和链表的分离,一旦数据改变则链表就不能用了,就要重新开发. 如上说示:外层是Teacher,里面小的是node. #ifndef _MYLINKLIST_H_ #define _ ...
- java常用的包的简介
java常用的包: java.lang:包含java语言的核心类,如String.math.system和thread类等,使用这个包下的类无需import导入,系统会自动导入这个包下的所有类. ...
- 如何去除掉inline-block元素之间的默认间距
前几天写一个页面 div{width:900px;} div li{ display:inline-block; width:300px;} <ul> <li></li& ...