JSP知识点总结

一、jsp静态包含和动态包含的区别

  在学习request对象的时候,我们曾经使用过request.getRequestDispatcher(String url).include(request,response)来对页头和页尾面进行包含。inclue指令也是做这样的事情,一起来试验一下吧。

这是页头

   <%@ page contentType="text/html;charset=UTF-8" language="java"   %>

    <html>

        <head>

            <title>页头</title>

        </head>

        <body>

        我是页头

        <br>

        <br>

        <br>

        </body>

    </html>

这是页尾

 <%@ page contentType="text/html;charset=UTF-8" language="java" %>

    <html>

    <head>

        <title>页尾</title>

    </head>

    <body>

    

    我是页尾

    

    </body>

    </html>

在index.jsp中把页头和页尾包含进来

  <%@ page contentType="text/html;charset=UTF-8" language="java" %>

    <html>

    <head>

        <title>包含页头和页尾进来</title>

    </head>

    <body>


    <%@include file="head.jsp" %>

    <%@include file="foot.jsp" %>

    </body>

    </html>

  ● include指令是静态包含。静态包含的意思就是:把文件的代码内容都包含进来,再编译!

  ● include行为是动态包含。其实include行为就是封装了request.getRequestDispatcher(String url).include(request,response)。

include行为语法是这个样子的

    <jsp:include page=""/>

  ● jsp行为包含文件就是先编译被包含的页面,再将页面的结果写入到包含的页面中(index.jsp)

  当然了,现在有静态包含和动态包含,使用哪一个更好呢?答案是:动态包含。动态包含可以向被包含的页面传递参数(用处不大),并且是分别处理被包含页面的(将被包含页面编译后得出的结果再写进包含页面)【如果有相同名称的参数,使用静态包含就会报错!】!

总结

  ● <%@include file="xxx.jsp"%>为jsp中的编译指令,其文件的包含是发生在jsp向servlet转换的时期,而<jsp:include page="xxx.jsp">是jsp中的动作指令,其文件的包含是发生在编译时期也就是将java文件编译为class文件的时期

  ● 使用静态包含只会产生一个class文件,而使用动态包含会产生多个class文件

  ● 使用静态包含,包含页面和被包含页面的request对象为同一对象,因为静态包含只是将被包含的页面的内容复制到包含的页面中去;而动态包含包含页面和被包含页面不是同一个页面,被包含的页面的request对象可以取到的参数范围要相对大些,不仅可以取到传递到包含页面的参数,同样也能取得在包含页面向下传递的参数

二、jsp有哪些内置对象?作用分别是什么?

九个内置对象:

  ● pageContext

  ● page

  ● config

  ● request

  ● response

  ● session

  ● application

  ● exception

  ● out

  其中,request、response、session、application、config这五个对象和Servlet的API是一样的。这5个对象我就不解释了。在JSP中,尤其重要的是pageContext对象pageContext是内置对象中最重要的一个对象,它代表着JSP页面编译后的内容(也就是JSP页面的运行环境)

pageContext对象

  既然它代表了JSP页面编译后的内容,理所当然的:它封装了对其他8大内置对象的引用!也就是说,通过pageContext可以获取到其他的8个内置对象

   <%@ page contentType="text/html;charset=UTF-8" language="java" %>

    <html>

    <head>

        <title>获取八大内置对象</title>

    </head>

    <body>

    <%

        System.out.println(pageContext.getSession());

        System.out.println(pageContext.getRequest());

        System.out.println(pageContext.getResponse());

        System.out.println(pageContext.getException());

        System.out.println(pageContext.getPage());

        System.out.println(pageContext.getServletConfig());

        System.out.println(pageContext.getServletContext());

        System.out.println(pageContext.getOut());

    %>

    </body>

</html>

● pageContext作为域对象

  类似于request,session,ServletContext作为域对象而言都有以下三个方法:

    ● setAttribute(String name,Objcet o)

    ● getAttribute(String name)

    ● removeAttribute(String name)

  当然了,pageContext也不例外,pageContext也有这三个方法。pageContext本质上代表的是当前JSP页面编译后的内容,作为域对象而言,它就代表着当前JSP页面(也就是page)!也就是说:pageContext域对象只在page范围内有效,超出了page范围就无效了。

  pageContexst还有这么一个方法:findAttribute(String name),该方法会查找各个域的属性,从小到大开始寻找,也就是page—>request->session->application

out对象:

out对象用于向浏览器输出数据,与之对应的是Servlet的PrintWriter对象。然而这个out对象的类型并不是PrintWriter,是JspWriter。我们可以简单理解为:JspWriter就是带缓存的PrintWrieter。

out对象的原理如下:

  只有向out对象中写入了内容,且满足如下任何一个条件时,out对象才去调用ServletResponse.getWriter方法,并通过该方法返回的PrintWriter对象将out对象的缓冲区中的内容真正写入到Servlet引擎提供的缓冲区中:

  ● 设置page指令的buffer属性关闭了out对象的缓存功能

  ● out对象的缓冲区已满

  ● 整个JSP页面结束

  一般我们在JSP页面输出都是用表达式(<%=%>),所以out对象用得并不是很多!

page对象

内置对象page是HttpJasPage对象,其实page对象代表的就是当前JSP页面,是当前JSP编译后的Servlet类的对象。也就是说:page对象相当于普通java类的this

exception对象

内置对象exception是java.lang.Exception类的对象,exception封装了JSP页面抛出的异常信息。exception经常被用来处理错误页面

总结

  1.request 用户端请求,此请求会包含来自GET/POST请求的参数

  2.response 网页传回用户端的回应

  3.pageContext 网页的属性是在这里管理,代表的编译后JSP内容

  4.session 与请求有关的会话期

  5.application servlet 正在执行的内容

  6.out 用来传送回应的输出

  7.config servlet的构架部件

  8.page JSP网页本身

  9.exception 针对错误网页,未捕捉的例外

三、jsp和servlet的区别、共同点、各自应用的范围?

  ● JSP是Servlet技术的扩展,本质上就是Servlet的简易方式。JSP编译后是“类servlet”。

  ● Servlet和JSP最主要的不同点在于:Servlet的应用逻辑是在Java文件中,并且完全从表示层中的HTML里分离开来。而JSP的情况是Java和HTML可以组合成一个扩展名为.jsp的文件。

  ● JSP侧重于视图,Servlet主要用于控制逻辑。

1.属性作用域范围

  ● page【只在一个页面中保存属性,跳转页面无效】

  ● request【只在一次请求中保存属性,服务器跳转有效,浏览器跳转无效】

  ● session【在一个会话范围中保存属性,无论何种跳转均有效,关闭浏览器后无效】

  ● application【在整个服务器中保存,所有用户都可以使用】

2.应用场景:

  ● request:如果客户向服务器发请求,产生的数据,用户看完就没用了,像这样的数据就存在request域,像新闻数据,属于用户看完就没用的

  ● session:如果客户向服务器发请求,产生的数据,用户用完了等一会儿还有用,像这样的数据就存在session域中,像购物数据,用户需要看到自己购物信息,并且等一会儿,还要用这个购物数据结帐

  ● servletContext:如果客户向服务器发请求,产生的数据,用户用完了,还要给其它用户用,像这样的数据就存在servletContext域中,像聊天数据

四、写出5种JSTL常用标签

  <c:if>,<c:item>,<c:foreach>,<c:out>,<c:set>

五、写一个自定义标签要继承什么类

我们可以有两种方式来实现自定义标签:

  ● 传统方式,实现Tag接口(老方法)

  ● 简单方式,继承SimpleTagSupport类

SimpleTagSupport类的执行顺序(原理):

  ①WEB容器调用标签处理器对象的setJspContext方法,将代表JSP页面的pageContext对象传递给标签处理器对象

  ②WEB容器调用标签处理器对象的setParent方法,将父标签处理器对象传递给这个标签处理器对象。【注意,只有在标签存在父标签的情况下,WEB容器才会调用这个方法】

  ③如果调用标签时设置了属性,容器将调用每个属性对应的setter方法把属性值传递给标签处理器对象。如果标签的属性值是EL表达式或脚本表达式,则WEB容器首先计算表达式的值,然后把值传递给标签处理器对象。

  ④如果简单标签有标签体,容器将调用setJspBody方法把代表标签体的JspFragment对象传递进来

  ⑤执行标签时:容器调用标签处理器的doTag()方法,开发人员在方法体内通过操作JspFragment对象,就可以实现是否执行、迭代、修改标签体的目的。

总结

SimpleTagSupport,一般调用doTag方法或者实现SimpleTag接口。

六、JSP是如何被执行的?执行效率比Servlet低吗?

  ● 当客户端向一个jsp页面发送请求时,Web Container将jsp转化成servlet的源代码(只在第一次请求时),然后编译转化后的servlet并加载到内存中执行,执行的结果response到客户端。

  ● jsp只在第一次执行的时候会转化成servlet,以后每次执行,web容器都是直接执行编译后的servlet,所以jsp和servlet只是在第一次执行的时候不一样,jsp慢一点,以后的执行都是相同的。

七、如何避免jsp页面自动生成session对象?为什么要这么做?

可以使用页面指令显式关掉,代码如下:

<%@ page session="false" %> 

八、jsp的缺点?

  1)不好调试

  2)与其他脚本语言的交互(可读性差)

九、说出Servlet和CGI的区别?

  ● Servlet处于服务器进程中,只会有一个servlet实例,每个请求都会产生一个新的线程,而且servlet实例一般不会销毁

  ● CGI:来一个请求就创建一个进程,用完就销毁,效率低于servlet

十、简述JSP的设计模式。

  在Web开发模式中,有两个主要的开发结构,称为模式一(Mode I)模式二(Mode II)。

  首先我们来理清一些概念:

DAO(Data Access Object):主要对数据的操作,增加、修改、删除等原子性操作。

  ● Web层:界面+控制器,也就是说JSP【界面】+Servlet【控制器】。

  ● Service业务层:将多个原子性的DAO操作进行组合,组合成一个完整的业务逻辑。

  ● 控制层:主要使用Servlet进行控制。

  ● 数据访问层:使用DAO、Hibernate、JDBC技术实现对数据的增删改查。

  ● JavaBean用于封装数据,处理部分核心逻辑,每一层中都用到。

  模式一指的就是在开发中将显示层、控制层、数据层的操作统一交给JSP或者JavaBean来进行处理。模式一有两种情况:

  ● 完全使用JSP做开发:

优点:

      开发速度贼快,只要写JSP就行了,JavaBean和Servlet都不用设计!

      小幅度修改代码方便,直接修改JSP页面交给WEB容器就行了,不像Servlet还要编译成.class文件再交给服务器!【当然了,在ide下开发这个也不算是事】

缺点:

      程序的可读性差、复用性低、代码复杂!什么jsp代码、html代码都往上面写,这肯定很难阅读,很难重用!

  ● 使用JSP+JavaBean做开发:

优点:

      程序的可读性较高,大部分的代码都写在JavaBean上,不会和HTML代码混合在一起,可读性还行的。

      可重复利用高,核心的代码都由JavaBean开发了,JavaBean的设计就是用来重用、封装,大大减少编写重复代码的工作!

缺点:

      没有流程控制,程序中的JSP页面都需要检查请求的参数是否正确,异常发生时的处理。显示操作和业务逻辑代码工作会紧密耦合在一起的!日后维护会困难

  Mode II 中所有的开发都是以Servlet为主体展开的,由Servlet接收所有的客户端请求,然后根据请求调用相对应的JavaBean,并所有的显示结果交给JSP完成!,也就是俗称的MVC设计模式!

MVC设计模式:

  ● 显示层(View):主要负责接受Servlet传递的内容,调用JavaBean,将内容显示给用户

  ● 控制层(Controller):主要负责所有用户的请求参数,判断请求参数是否合法,根据请求的类型调用JavaBean,将最终的处理结果交给显示层显示!

  ● 模型层(Mode):模型层包括了业务层,DAO层。

总结

  (1)ModelI,JSP+JavaBean设计模式。

  (2)ModelII,MVC设计模式。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏Seebug漏洞平台

从补丁到漏洞分析——记一次joomla漏洞应急

作者:LoRexxar'@知道创宇404实验室 2018年1月30日,joomla更新了3.8.4版本,这次更新修复了4个安全漏洞,以及上百个bug修复。 ht...

35012
来自专栏zhisheng

【死磕Java并发】—–深入分析Synchronized的实现原理

记得刚刚开始学习Java的时候,一遇到多线程情况就是synchronized,相对于当时的我们来说synchronized是这么的神奇而又强大,那个时候我们赋予...

912
来自专栏北京马哥教育

Python爬虫实战之使用Scrapy爬起点网的完本小说

作者:totcw 来源:http://blog.csdn.net/totcw/article/details/65444660 一.概述 本篇的目的是用scr...

3537
来自专栏芋道源码1024

【死磕Java并发】—–深入分析synchronized的实现原理

记得刚刚开始学习Java的时候,一遇到多线程情况就是synchronized,相对于当时的我们来说synchronized是这么的神奇而又强大,那个时候我们赋予...

3518
来自专栏微信公众号:Java团长

成为Java顶尖程序员,先过了下面问题!

741
来自专栏程序猿DD

死磕Java并发:深入分析synchronized的实现原理

记得刚刚开始学习Java的时候,一遇到多线程情况就是synchronized。对于当时的我们来说,synchronized是如此的神奇且强大。我们赋予它一个名字...

1347
来自专栏Java学习之路

Java并发之底层实现原理学习笔记

本篇博文将介绍java并发底层的实现原理,我们知道java实现的并发操作最后肯定是由我们的CPU完成的,中间经历了将java源码编译成.class文件,然后进行...

3366
来自专栏Laoqi's Linux运维专列

python3–内置模块

4276
来自专栏Java后端技术栈

Java多线程编程-(13)-从volatile和synchronized的底层实现原理看Java虚拟机对锁优化所做的努力

对于Java来说我们知道,Java代码首先会编译成Java字节码,字节码被类加载器加载到JVM里,JVM执行字节码,最终需要转化为汇编指令在CPU上进行执行。

831
来自专栏java技术学习之道

Java日志框架:logback详解

2825

扫码关注云+社区