今天我们聊聊JSP开发中的Model1和Model2。
Model1采用了JSP+JavaBean技术开发Web应用。其中,JSP实现页面显示,业务逻辑和流程控制,数据处理由JavaBean完成。在JSP技术使用初期,这里以JSP为中心的Model1曾占有统治地位。Model1的有点就在于进行快速和小规模的应用开发时的优势非常明显。JSP页面肚子响应请求并经过处理后把返回给客户端,JavaBean实现数据处理,这样做简单,易于实现,开发效率高,并实现了页面显示和内容的分离。但是Model1的使用也带了很多问题。首先,由于业务逻辑是由一组JSP页面完成,因此如果要进行改动,必须在多个地方进行修改,这样非常不利于Web应用的扩展和更新,所有的Web应用将业务逻辑封装到JavaBean中去实现。其次,JSP页面中内嵌了大量的JAVA代码,当业务逻辑复杂时,情况就变得非常糟糕,调试和排错变得异常困难,代码的可维护性随之下降。最后,由于Model1中显示,业务和流程混杂在一起,这就导致了在开发过程中的角色定义不请和职责分配不明,给项目管理带来了很大的麻烦。
Model2采用了JSP+Servlet+JavaBean技术开发Web应用。该模型基于MVC模式,完全实现了页面显示和逻辑分离。模型层为JavaBean实现数据的表示和业务逻辑,视图层为JSP页面,只负责显示功能,控制器为Servlet,负责接收用户的请求,设置JavaBean属性,调用JavaBean完成业务处理,最后将处理结果交给JSP页面显示。在此模型中,Servlet分担了Model1中JSP的大部分工作,将JSP从请求接收和流程控制中解放出来,业务逻辑也交给了JavaBean完成,这种方式充分利用了JSP和Servlet两种技术的有点,JSP更适合前台页面的开发,而Servlet更擅长服务器端程序的编写。
总结:Model1和Model2实际上就是对用JSP技术开发的Web应用的不同模型描述。
Model1采用JSP+JavaBean技术开发Web应用,它比较适合小规模应用的开发,效率复杂时,代码的可维护性,可扩展性和可重用性下降。Model2采用JSP+Servlet+JavaBean技术开发Web应用。该模型基于MVC模式,完全实现了页面显示和逻辑的分离,它充分利用了JSP和Servlet两个技术的优点,JSP更适合前台页面的开发,而Servlet更擅长服务器端程序的编写。Model2分工明确,更适合大型项目的开发和管理。