JSP的底层和本质以及语法详解!
一、JSP是什么底层,本质是什么?
JSP搜索翻译引擎(;底层是Java程序,本质上是Servlet
JSP是:JavaServer Pages的缩写。(基于Java语言实现的服务器端的页面。)
JSP是一套规范。所有的web容器/web服务器都是遵循这套规范的,都是按照这套规范进行的“翻译”
pageContext < request < session < application 这四个作用域都有:setAttribute、getAttribute、removeAttribute方法。作用域的使用原则:尽可能使用小的域。
javax.servlet.jsp. PageContext pageContext 页面作用域
javax.servlet.http. HttpServletRequest request 请求作用域
javax.servlet.http. HttpSession session 会话作用域
javax.servlet. ServletContext application 应用作用域
java.lang. Throwable exception 异常
javax.servlet. ServletConfig config 配置文件以key=value形式出现;key重复value覆盖
java.lang. Object page (其实是this,当前的servlet对象)
javax.servlet.jsp. JspWriter out (负责输出:out.write("") )
JSP中编写Java程序:
JSP的注释:<%-- JSP的专业注释,不会被翻译到java源代码当中。--%>; <!-- 这种HTML的注释,会被翻译到java源代码当中-->
JSP基础语法:
JSP中直接编写普通字符串 ;会直接输出到浏览器上面
<%%>被翻译到service方法内 的 :out.write("这里");同一个JSP当中 <%%> 这个符号可以出现多个。
<%= %> 被翻译到 service方法内的: out.print(); 在=的后面编写要输出的“java代码”内容。
被翻译到 Servlet 类的service方法内部。需要时刻记住正在“service方法体”当中写代码;
在service方法当中编写的代码是有顺序的,方法体当中的代码要遵循自上而下的顺序依次逐行执行。
service方法当中不能出现:静态代码块,方法,成员变量;
<%! %>翻译到service方法之外。这个语法很少用,,因为在service方法外面写静态变量和实例变量,都会存在线程安全问题,因为JSP就是servlet,servlet是单例的;
多线程并发的环境下,这个静态变量和实例变量一旦有修改操作,会存在线程安全问题。
JSP指令指导当前的JSP翻译引擎如何翻译JSP文件:
<%@page contentType="text/json" %>
contentType属性用来设置响应的内容类型;但同时也可以设置字符集。
<%@page contentType="text/json;charset=UTF-8" %>
<%@page session="true" %>
true表示一定启动session对象。没有session对象会创建。如果没有设置,默认值就是session="true"
<%@page session="false" %>
session="false" 表示不启动内置对象session。当前JSP页面中无法使用内置对象session。
<%@page pageEncoding="UTF-8" %>
pageEncoding="UTF-8" 表示设置响应时采用的字符集。
<%@page import="java.util.List, java.util.Date, java.util.ArrayList" %>
<%@page import="java.util.*" %>
import语句,导包。
<%@page errorPage="/error.jsp" %>
当前页面出现异常之后,跳转到error.jsp页面。errorPage属性用来指定出错之后的跳转位置。
<%@page isErrorPage="true" %>
表示启用JSP九大内置对象之一:exception;默认值是false。
JSP本质上是一个Servlet,那么JSP和Servlet到底有什么区别?
职责不同:Servlet的职责是什么:收集数据。(Servlet的强项是逻辑处理,业务处理,然后链接数据库,获取/收集数据。)
JSP的职责是什么:展示数据。(JSP的强项是做数据的展示)
在jsp文件中直接编写文字,都会自动被翻译到哪里?
翻译到servlet类的service方法的out.write("翻译到这里"),直接翻译到双引号里,被java程序当做普通字符串打印输出到浏览器。
在JSP中编写的HTML CSS JS代码,这些代码对于JSP来说只是一个普通的字符串。但是JSP把这个普通的字符串一旦输出到浏览器,浏览器就会对HTML CSS JS进行解释执行。展现一个效果。
为什么大部分的运维伙伴在给客户演示项目的时候,为什么提前先把所有的jsp文件先访问一遍。为什么?
jsp文件第一次访问的时候是比较慢的,要把jsp文件翻译生成java源文件
java源文件要编译生成class字节码文件;然后通过class去创建servlet对象;
然后调用servlet对象的init方法;最后调用servlet对象的service方法。
第二次就比较快了, 因为第二次直接调用单例servlet对象的service方法即可。
第一个JSP程序:
在WEB-INF目录之外创建一个index.jsp文件,然后这个文件中没有任何内容。项目部署之后,启动服务器,打开浏览器,
访问以下地址:http://localhost:8080/jsp/index.jsp 展现在面前的是一个空白。
实际上访问以上的这个:index.jsp,底层执行的是:index_jsp.class 这个java程序。
这个index.jsp会被Tomcat翻译生成index_jsp.java文件,然后tomcat服务器又会将index_jsp.java编译生成index_jsp.class文件
访问index.jsp,实际上执行的是index_jsp.class中的方法。
JSP实际上就是一个Servlet。
index.jsp访问的时候,会自动翻译生成index_jsp.java,会自动编译生成index_jsp.class,那么index_jsp 这就是一个类。
index_jsp 类继承 HttpJspBase,而HttpJspBase类继承的是HttpServlet。所以index_jsp类就是一个Servlet类。
jsp的生命周期和Servlet的生命周期完全相同。完全就是一个东西。没有任何区别。
jsp和servlet一样,都是单例的。(假单例。)
JSP程序的代码出错之后应该如何调试?!
开发JSP的时候:眼前是JSP代码,但是脑海中呈现出来的是java代码。
复制黄色线框内的路径》然后依次去找以下文件>work>Catalina>localhost>jsp>项目名>org>apache>jsp
打开以Java结尾的文件,找到Service 方法;查看源代码
javabean其实就是java中的实体类。负责数据的封装。由于javabean符合javabean规范,具有更强的通用性。
javabean(java的logo是一杯冒着热气的咖啡。javabean被翻译为:咖啡豆)java是一杯咖啡,咖啡由一粒一粒的咖啡豆研磨而成。
整个java程序中有很多bean的存在。由很多bean组成。实际上javabean你可以理解为符合某种规范的java类,比如:
-->有无参数构造方法-->属性私有化-->对外提供公开的set和get方法-->实现java.io.Serializable接口-->重写toString-->重写hashCode+equals
JSP文件的扩展名必须是xxx.jsp吗?
jsp文件的扩展名是可以配置的。不是固定的。
在CATALINA_HOME/conf/web.xml,在这个文件当中配置jsp文件的扩展名。
<servlet-mapping>
<servlet-name>jsp</servlet-name>
<url-pattern>*.jsp</url-pattern>
<url-pattern>*.jspx</url-pattern>
</servlet-mapping>