JSP全名为Java Server Pages,百科上介绍它根本上是一个简化的Servlet设计。Servlet(Server Applet)是Java Servlet的简称,称为小服务程序或服务连接器。Servlet 的主要功能在于交互式地浏览和修改数据,生成动态 Web 内容。这个过程为:
- 客户端发送请求至服务器端;
- 服务器将请求信息发送至 Servlet;
- Servlet 生成响应内容(如HTML)并将其传给服务器;
- 服务器将响应返回给客户端。
我在网上看了一些资料后,觉得在讨论MVC与JSP的异同之前,先讨论Servlet和JSP的异同更好理解。
Servlet和JSP
JSP既然是是一个简化的Servlet设计,它和Servlet一样是用于交互式地浏览和修改数据,生成动态 Web 内容。那么二者的不同之处呢。
不同
- Servlet在Java代码中通过HttpServletResponse对象动态输出HTML内容
- JSP在静态HTML内容中嵌入Java代码,Java代码被动态执行后生成HTML内容
二者各有优缺点,Servlet是在Java中通过比如字符串拼接的方式生成HTML代码(我们在思沃影院中就用这种方法修改的HTML),这样虽然可以很好的生成业务逻辑代码,但是它的HTML代码却也因此而可读性低,维护困难。而JSP通过在HTML中嵌入Java代码规避了这一点,但是却在HTML中混入了大量的业务代码,同样造成了维护困难。
对于这两者的缺点,我还有一点理解:很多的程序员可能美工能力不太好,这样使用Servlet的话,在设计出美观的UI方面可能就会有难度;而JSP的模式,在HTML中混入大量的业务逻辑代码,又造成了前端工程师的负担。
MVC
我们可以看出,Selvlet和JSP的优缺点是互补的,那么为什么不找一种【互补】的更好的模式呢。这种模式就是MVC.
MVC的名字即就是它的三个基本部分:Model-View-Controller
其中
- Controller——负责转发请求,对请求进行处理
- View——负责界面显示
- Model——业务功能编写(例如算法实现)、数据库设计以及数据存取操作实现
结构分工很清楚,从我自己的经历就可以很切实地体会到MVC的优点。我在刚开始写代码的时候,总是把代码写在一个文件里,后来项目慢慢变复杂一些,我也总是把很多的业务逻辑集中在一两个文件里,或者分了好几个文件,却分得很乱。后来经过项目规范,开始按照规范,也即按照代码的分工,来分包分文件写代码,代码的可读性可维护性都大大提高,其实代码的具体实现是差不多的,但按照规范分块后的代码时绝对比之前的要好的。
下面就通过MVC中三个??榈木咛夤ぷ髁鞒汤锤惺芟翸VC时怎样结合了Servlet和JSP的优点的。
- 客户端发送请求后,Controller获取请求,解析请求后调用相应的Model
- 业务逻辑Model产生相应的逻辑结果,并交给Controller
- Controller将逻辑结果交给View,View动态生成HTML
- HTML返回给客户端显示
可见,MVC将业务逻辑和HTML分开,既能很好的组织业务逻辑,又能生成高可读性的HTML,HTML中也不会混入大量的业务逻辑。Controller和Model吸收的了Serlvet的优点,而View就吸收了JSP的优点,自然地也克服了他们各自的缺点。