在早期的JavaWeb应用中,JSP文件负责处理业务逻辑,控制网页流程并创建HTML页面,JSP文件是一个独立的,能自主完成所有任务的模块,
这带来了一系列问题:
- HTML代码和Java程序代码强耦合在一起
- 内嵌的流程控制逻辑
- 调试困难
- 可维护性差
- 可读性差
为了解决以上问题,SUN公司先后制定了两种设计模式:
JSP Model1 and JSP Model2
JSP Model1 和 JSP Model2 的本质区别在于负责流程控制的组件不同。
JSP Model1
在JSP Model1中,JSP页面负责调用模型组件来响应客户请求,并将处理结果返回给用户。JSP既要负责流程控制,还要负责产生用户界面,因此它要同时充当视图和控制器的需要,但它不适合开发复杂的大型应用程序。
JSP 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表达式和定制标签来显示值。