浅析JSP页面翻译的原理 |
本文标签:JSP页面翻译 众所周知,每一个JSP页面都会被Web容器编译成一个Java类,供Web容器调用,并且生成HTML叶面回馈给用户 。而了解其中的变异方法和规则,对我们学习JSP是非常有好处的,可以说学习好了这个编译原理,就已经学习好了大部分的JSP知识,剩下的工作就只剩下熟记一些tablib和反复应用以使自己更加熟练而已了 。 先来看一下JSP页面所对应的Class的基本结构 。每一个JSP页面都会被编译成成如下的格式样子,先给一个大致的印象,详细的说明在后面 这里面最重要的函数就是pageservice,web容器在编译好一个JSP类以后,就申请这个类的对象,并且直接调用pageservice来获得Response,最后返回给客户 。作为细节,我们可以总结如下: 1.所有的JSP页面翻译出来的class,都从HttpJspBase继承,并且命名为PageName$jsp 。 2.在第一次调用pageservice函数的时候,该class会进行一次初始化,而这个初始化函数是_jspx_init,如果我们想,我们还可以自定义这个函数,来实现JSP页面的初始化 。 3.<% %> 这样的代码被转换成什么了? 4.<%! %> 这样的代码被转换成什么了? 5.HTML代码呢? 6.为什么JSP页面翻译有那么多省写方式,比如说session , out , page , context之类 。 7.省写方式<%= object.doSomething()%> 这么理解? 8.JavaBean 里面的scope定义了作用域范围,这个范围在这里的意思是? 9.关于<%@ page %>命令,这个就太简单了,只是一个一个的对应为response.setContentType()的语句而已 。 10.关于JSP页面翻译转向问题 。这个语句被翻译为getServletContext().getRequestDispatcher("/List.jsp").forward(req, res);语句 。 11.<%@ include file="included.jsp" %> 遇到这个语句,JSP翻译器就会把这个文件的代码和现在文件的代码混合然后一起编译,生成JSP类 。这个方法很好,可以让我们统一文档的样式,比如说吧 header写成一个文件,,而把footer也写成一个JSP ,并且在index.html里面把这两个文件包含近来,这样,不管Content怎么变,上下样式都不会变,有利于样式的统一 。 以上是JSP页面翻译过程的简单探讨,更加详细的细节可以参考tomcat的源代码,了解这些原理对于学习JSP来说,是非常重要的,能大大的提高学习的效率 。 |