JSP编译成Servlet(四)JSP与Java行关系映射

我们知道java虚拟机只认识class文件,要在虚拟机上运行就必须要遵守class文件格式,所以JSP编译成servlet后还需要进一步编译成class文件,但从JSP文件到java文件再到class文件的过程需要考虑的事情比较多,其中一个比较重要的就是调试问题,由于语法不一样,jsp某行执行的逻辑怎样与java文件对应起来,这样在JVM执行过程发生异常或错误才能找到JSP对应的行,提供一个友好的调试信息。类似的,jsp文件名编译后的java文件名同样也要有映射关系。

    总的来说,为了解决从非java语言到java语言调试时文件名及行号映射的问题,java community process组织提出了JSR-45(Debugging Support for Other Languages)规范,它为非java语言提供了一个进行调试的标准机制。这里的JSP其实就是属于非java语言,JSP如果想要方便开发者开发,它就必须要遵循JSR-45规范。其实可以简单的说就是为了解决JSP编译后的java文件与JSP文件的对应关系,而且是提供一个统一的标准,从而避免不同厂商有不同的实现方式。

JSR-45规范的核心对象是资源映射表(Source Map),简称SMAP。在这里它是指JSP文件文件名及行号的映射表,这个映射表存放到class文件中,在基于JPDA的调试工具中就可以通过此映射表获取到对应JSP文件及行号,向开发者提示对应JSP文件的信息。

接下去以前面的HelloWorld.jsp例子看看SMAP映射表是如何映射的,HelloWorld.jsp文件被编译后变成HelloWorld_jsp.java文件,根据JSR-45的规范最终我们会生成一份如下的映射表,这里不打算探究SMAP的整个语法,只专注行号映射相关的部分,即从*L到*E中间的内容,其中1,10:62表示HelloWorld.jsp文件与HelloWorld_jsp.java的映射关系为1-62、2-63、3-64、...10-71。同样的,10,3:72表时的对应关系为10-72、11-73、12-74。有了这些映射表就可以方便地将java执行的行号与JSP的行号对应起来了。

SMAP

HelloWorld_jsp.java

JSP

*S JSP

*F

+ 0 HelloWorld.jsp

HelloWorld.jsp

*L

1,10:62

10,3:72

*E

说完SMAP,我们已经知道生成的SMAP的格式,那么要如何保存?保存到哪里呢?因为JVM只会通过Class文件去加载相关信息,所以唯一的办法是通过class文件附带SMAP消息,class文件格式中可以附带信息的就只有属性表集合,在class文件格式中其他数据项都有严格的长度、顺序和格式,而属性列表集合则没有严格要求,只要属性名不与已有属性冲突即可,任何人都可以往class文件的属性列表中写入自定义的属性,虚拟机会自动忽略不认识的属性,所以我们需要在支持调试信息的JVM中附带此属性,这里的属性名称就是SourceDebugExtension属性。这个属性的结构如下,首先2个字节表示名称的索引值,接着4个字节表示属性长度,最后一个数组表示属性值。按照格式写入class文件JVM即可识别。

SourceDebugExtension_attribute {

u2 attribute_name_index;

u4 attribute_length;

u1 debug_extension[attribute_length];

}

通过JSR45标准解决了JSP到java之间的映射关系问题,从而让调试更加方便。在Java的世界中为了达到统一而又不失灵活,基本都是由java community process制定规范然后由厂商按照规范进行实现。

点击订购作者《Tomcat内核设计剖析》

时间: 2024-09-10 23:17:59

JSP编译成Servlet(四)JSP与Java行关系映射的相关文章

JSP编译成Servlet(三)JSP编译后的Servlet

JSP编译后的Servlet类会是怎样的呢他们之间有着什么样的映射关系在探讨JSP与Servlet之间的关系时先看一个简单的HelloWorld.jsp编译成HelloWorld.java后会是什么样. ①HelloWorld.jsp <%@ page contentType="text/html; charset=gb2312" language="java" %> <!DOCTYPE HTML PUBLIC "-//W3C//DTD

JSP编译成Servlet(一)语法树的生成——语法解析

一般来说,语句按一定规则进行推导后会形成一个语法树,这种树状结构有利于对语句结构层次的描述.同样Jasper对JSP语法解析后也会生成一棵树,这棵树各个节点包含了不同的信息,但对于JSP来说解析后的语法树比较简单,只有一个父节点和n个子节点.例如node1是表示形如<!-- 字符串 -->的注释节点,节点里面包含了一个表示注释字符串的属性:而node2则可能是表示形如<%= a+b %>的表达式节点,节点里面包含一个表示表达式的属性,同样地其他节点可能表示JSP的其他语法,有了这棵

JSP编译成Servlet(二)语法树的遍历——访问者模式

语法树可以理解成是一种数据结构,假如某些语句已经被解析成一棵语法树,那么接下来就是要对此语法树进行处理,但考虑到不将处理操作与数据结构混合在一块,我们需要一种方法将其分离.其实对于语法树的处理最典型的处理模式就是访问者模式,它能很好的将数据结构与处理分离,提供了很好的解耦作用,让我们可以在生成语法树的过程只需关注如何构建相关的数据结构,而在对语法树处理的时候只需关注处理的逻辑,是一种非常巧的设计模式,接下来通过一个简单的代码案例看看如何实现一个访问者模式. ①定义访问者操作方法接口,声明所有访问

如何使用ant调用WebSphere的编译器将jsp编译成jar包?

问题描述 我们现有的项目是运行在tomcat5下,jsp是通过使用tomcat提供的org.apache.jasper.JspC编译工具将JSP页面的预编译.把所有JSP编译后得到的.class打包成一个xxx.jar包,放在我们应用的lib中.然后在web.xml中分别设置为servlet,再映射到某个xxx.jsp的URL上.build.xml文件如下:<projectname="WebappPrecompilation"default="all"base

脱离ws_ant直接使用Ant调用WebSphere编译器将jsp编译成class

http://yulimin.javaeye.com/blog/412504   引子: 引用 tomcat5下,jsp是通过使用tomcat提供的org.apache.jasper.JspC编译工具将JSP 页面的预编译 在WAS当中是通过 Java代码 com.ibm.websphere.ant.tasks.JspC   完整的Ant脚本 build.xml 文件内容 Java代码 <?xml version="1.0" encoding="UTF-8"?

JSP转译成Servlet详细过程

JSP转译成Servlet详细过程 JSP转译成Servlet详细过程   JSP是Servlet的扩展,在没有JSP之前,就已经出现了Servlet技术.Servlet是利用输出流动态生成HTML页面,包括每一个HTML标签和每个在HTML页面中出现的内容.     由于包括大量的HTML标签.大量的静态文本及格式等,导致Servlet的开发效率极为低下.所有的表现逻辑,包括布局.色彩及图像等,都必须耦合在Java代码中,这的确让人不胜其烦.JSP的出现弥补了这种不足,JSP通过在标准的HTM

选择jsp而不是servlet作为BS前台主流方案是JAVA的战略性方向错误

js|servlet|错误|战略|主流  原文许多人认为JSP是JAVA向微软ASP挑战的成功产品,到今天,围绕着JSP方案发展出了TAG/EL等技术,JSP作为JAVA的BS前台界面方案看来已经是无法逆转.但在我看来,JAVA选择JSP这种表达形式,恰恰是它最失败的地方,是对ASP的一种拙劣的模仿,它本来可以做得更好的,甚至可能据此让微软彻底退出服务器领域,但最终,却可能成为足以令JAVA最终失败的重大战略方向性错误.JAVA到今天仍具有微软所有语言所不具备的优点,就以C#而言,只不过是形似而

Java Servlet 和 JSP入门教程(1)

js|servlet|教程|入门教程 Java Servlet 和 JSP教程(1) 1 概述 1.1 Java Servlet及其特点 Servlet是Java技术对CGI编程的回答.Servlet程序在服务器端运行,动态地生成Web页面.与传统的CGI和许多其他类似CGI的技术相比,Java Servlet具有更高的效率,更容易使用,功能更强大,具有更好的可移植性,更节省投资(更重要的是, Servlet程序员收入要比Perl程序员高:-): 高效 在传统的CGI中,每个请求都要启动一个新的

入门:非常基础)的Servlet/JSP配置详解

js|servlet|详解 初学者问的诸如:<怎样配置环境变量><怎样运行Servlet>啊?这样的问题太多了,现在我写一个初学者入门必读,以便对初学者有指导作用! 首先是下载工具: 我建议初学者用Editplus+JDK,我觉得如果用例如JB,Eclipse,JCreator,虽然刚开始的时候比较方便,但是确使初学者门不知道怎样配置环境变量,从而难以达到知其然,知其所以然的地步. 可以通过如下地址下载: Editplus(最新版本是v2.11):http://count.skyc