【转载】JSP详解(四大作用域九大内置对象等)

    前面讲解了Servlet,了解了Servlet的继承结构,生命周期等,并且在其中的ServletConfig和ServletContext对象有了一些比较详细的了解,但是我们会发现在Servlet中编写一些HTML代码,是很不方便的一件事情,每次都需要out.println(HTML); 因此就出现了JSP,来解决这样的问题,JSP中的内容就是html,但是能够嵌套java语言,现在来详细了解一下JSP。

                                  --WH

一、JSP

    1、什么是JSP?

       JSP(Java Server Pages):是以Java语言为基础的动态网页开发技术,

       特点:

          Servlet特点:在Java源码中嵌入html源码

          JSP特点:在html源码中嵌入java代码

       JSP就是Servlet

          1、tomcat获得JSP文件后,先将JSP转成servlet,变成xxx.java(servlet源码),

            D:\java\tomcat7.0\apache-tomcat-7.0.53\apache-tomcat-7.0.53\work\Catalina\localhost\test01\org\apache\jsp

          |------------------------------------------------------------------------|   |---------|----------|-------|-----------------|

                tomcat安装目录                        引擎   主机  项目   固定包名  这个之下就是存放着jsp变成的servlet文件.java和编译文件.class 

          2、tomcat将java文件编译成class文件

             

          3、tomcat运行class文件,并将结果输出到浏览器,

 

       实例:

          创建一个jsp。查看其转换后的servlet代码。

          NewFile.jsp          

 View Code

          NewFile_jsp.java          

 View Code

            可以看到public final class NewFile_jsp extends org.apache.jasper.runtime.HttpJspBase implements org.apache.jasper.runtime.JspSourceDependent

            NewFile_jsp.java继承自HttpJspBase。来看看HttpJspBase的源码

          HttpJspBase.java         

 View Code

          public abstract class HttpJspBase extends HttpServlet implements HttpJspPage

            看到了一个熟悉的类,HttpServlet,我们编写Servlet时就是继承自该类,这里也是继承HttpServlet,并且HttpJspBase的源码会发现,生命周期也是有init()方法,service()方法,destory()方法,相当于_jspService()方法就是servlet的service()方法的执行,所以说JSP也是一个servlet。

        

          我们在JSP写的所有html代码,都会被转换为servlet中的out.write(html)代码来输出。看图

              

 

 

       小总结:

              

           对于jsp转换成的servlet源码,之后我们会在进行详细分析,现在只需要知道jsp中的内容在servlet中被转换成什么了,在哪里被转换了即可。其中_jspService()方法的详细内容下面会讲解

           注意:jsp 生成java源码,默认第一次生成,之后直接执行,除非内容修改,具体点说,由于JSP只会在客户端第一次请求的时候被编译,因此第一次请求JSP时会感觉比较慢,而之后的请求因为不会编译JSP,所以速度就快多了,如果将Tomcat保存的JSP编译后的class文件删除,Tomcat也会重新编译JSP。在开发Web程序的时候经常需要修改JSP,Tomcat能够自动检测到JSP程序的改动,如果检测到JSP源代码发生了改动,Tomcat会在下次客户端请求JSP时重新编译JSP,而不需要重启Tomcat,这种自动检测功能默认是开启的,检测改动会消耗少量的时间,在部署web应用程序的时候可以在web.xml中将它关掉。这也就是为什么我们能够在jsp页面直接修改内容,而不用重新启动服务器的原因。

           因为JSP就是servlet,那么生命周期也就是跟serlvet一样。

           JSP和servlet有一点区别就在于:jsp是先部署后编译,而servlet是先编译后部署。

 

二、JSP语法

     JSP模版数据:

        就是JSP中的HTML代码,它的内容给是固定的,无论程序如何运行模版数据输出到客户端浏览器时都不会发生改变,当我们创建一个JSP时,模版就已经固定了。

     元素:JSP中的java部分,包括脚本(JavaScript,或者java代码)以及JSP指令(Directive)与JSP标签(Tag)等,元素决定着程序的流程,元素是不会显示到浏览器的。这几个都会在接下来讲解到

     JSP脚本:

        1、使用<% 编写java代码 %>,中间java代码必须遵循Java语法,

            

           为什么能够使用out输出?这里就涉及到了JSP的九大内置对象了,后面会讲解到,到时候回过头来在看看这里,就会知道为什么可以使用。

           来看看,jsp变为servlet时的代码是如何编写的。

            

          在JSP中JSP指令(后面会讲):

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

                  这句代码在servlet就变为了

                response.setContentType("text/html; charset=UTF-8");//这句代码的意思就是通知tomcat和浏览器都使用UTF-8码表,并且发送回浏览器的数据类型是text/html。这是有JSP指令中画红色部分代码转变的,而指令中的pageEncoding="UTF-8"的意思是JSP转换为Servlet时采用UTF-8码表编码,因为可能JSP中包含中文。

          对于JSP模版数据来说,就原封不动的使用out.write()来输出到浏览器

          而对于JSP元素来说,就会变成普通的java代码,因为在servlet中,就可以直接编写java代码。

                        

       2、使用<%=xxx %>来输出结果

            

          使用<%=result %>来输出结果,servlet中就会将其转换为out.print(result)进行输出。输出各种类型数据:int、double、boolean、String、Object等

              

       3、JSP注释

          <%-- --%>  :jsp注释,

          //  :java单行注释

          /*  */  :Java多行注释

          <!-- -->   :这个注释,会发送到浏览器端的源码中显示

          注释分别在servlet中如何显示的?

              

            

              

          JSP注释不会在servlet文件中显示,而java注释则会,但其所有的注释到了浏览器端,都不会出现在源码中,只有<!-- -->这个注释会到浏览器的网页源码中去

 

      4、JSP中申明方法与属性(全局变量)  使用<%!  方法、属性%>

          这个就不演示了,就是在JSP中编写方法或者属性时,使用<%! %>括起来。

              

       5、在JSP中使用if语句,或者使用for循环,whilt循环等都可以实现,也就是编写脚本而已。     

 

三、JSP指令

     指令用来申明JSP页面的一些属性,比如编码方式,文档类型。我们在servlet中也会申明我们使用的编码方式和响应的文档类型的,而JSP就是用指令来申明。上面我们也说到了一条指令,也就是page指令,

        JSP指令格式:<%@ directive {attribute=value}* %>

           解释:

              directive:指令名称,例如page指令

              attribute=value:紧跟指令名称后面的就是各种属性,以键值对的形式书写

              *:代表后面能跟0个或多个属性。

        例如: page指令:用来声明JSP页面的属性等。

           <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>  page指令,后面跟着三个属性,分别是language、contentType、pageEncoding。这只是其中的几个属性,并没有写全,page指令允许的属性如下表所示

        属性名称        取值范围          描述

        language        java      解释该JSP文件时采用的语言,一般为java语言,默认为java

        extends        任何类的全名   编译该JSP文件时继承哪个类,JSP为Servlet,因此当指明继承普通类时需要实现Servlet的init、destroy等方法

        import         任何包名、类名  引入该JSP中用到的类、包等,import是唯一可以声明多次的page指令属性,一个import可以引用uogelei,中间用英文逗号隔开,

                              如<%@ page import="java.util.List,java.util.ArrayList"%>

        session        true、false    该JSP内是否内置Session对象,如果为true,则内置Session对象,可直接使用,否则反之,默认为true

        autoFlush       true,false    是否运行缓存,如果为true,则使用out.println()等方法输出的字符串并不是立刻到达客户端服务器的,而是暂时存到缓存里,缓存满

                             了或者程序执行完毕或者执行out.flush()操作时才到客户端,默认为true。

        buffer        none或者数字KB   指定缓存大小,当autoFlush设为true时有效,例如<%@ page buffer=10kb%>

        isThreadSafe      true,false    是否线程安全,如果为true,则运行多个线程同时运行该jsp程序,否则只运行一个线程,其余线程等待,默认为false

        isErrorPage      true,false     指定该页面是否为错误显示页面,如果为true,则该JSP内置有一个Exception对象exception,可直接使用,否则没有,默认为false

        errorPage     某个JSP页面的相对路径  指明一个错误页面,如果该JSP程序抛出一个未捕捉的异常,则转到errorPage指定的页面,errorPage指定的页面通常

                               isErrorPage属性为true,且内置的exception对象为未捕捉的异常

        contentType     有效的文档类型    客户端浏览器根据该属性判断文档类型,例如 HTML格式为text/html、纯文本格式为text/plain、JPG图像为image/jpeg、GIF图                              像为image/gif、WORD文档为application/msword,该属性常跟着charset设置编码一起,作用是通知服务器和浏览器都使用同一                              个码表

        info          任意字符串      指明JSP的信息,该信息可以通过Servlet.getServletInfo()方法获取到

    trimDirective Whitespaces    true、false     是否去掉指令前后的空白字符,默认为false

        pageEncoding    UTF-8,ISO-8859-1等    指定一张码表来对该JSP页面进行编码,

        

      include指令

          比较简单,只有一种形式 <%@ include file="relativeURL"%>  relativeURL:本应用程序内另一个JSP文件或者HTML文件的路径,例如,网址内所有页面均有一个统一风格的导航栏和页脚版权,那么就可以使用该指令将其包含进来,  

          特点:include指令会将包含页面的源代码添加到使用include指令的页面中来,然后编译成class文件,而等下会讲到的一个JSP行为,<jsp:include page="relativeURL">作用跟include指令一样,但是不同的是,include行为是运行时单独执行包含页面,然后把执行的结果包含到本页面来,属于先运行后包含。

      taglib指令

          JSP支持标签技术,后面会讲到标签的用法,jstl标签库的使用等,

          作用:用来指明JSP页面内使用的JSP标签库,taglib指令有两个属性,uri为类库的地址,prefix为标签的前缀

          <%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%>

       

四、JSP行为

     前面讲了JSP语法,介绍了JSP页面中的内容有哪些,分别有什么作用,就两个东西,模块数据和元素。其中元素有包括脚本,指令,标签,脚本就是JSP中嵌入java代码,指令作用就是申明页面的属性,那标签是干嘛的,标签分为JSP自带内置的标签,和通过taglib指令来使用JSP标签库,或者自定义标签。现在我们先来讲一些JSP内置的标签。

     JSP内置的标签就被称为JSP行为(JSP Actions)。只要书写很少的标记代码就能使用JSP提供的丰富功能,JSP行为其实是对常用的JSP功能的抽象与封装,可以取代jsp脚本,让JSP中就少一些嵌入java代码的地方。

      格式:<jsp:elements {attribute="value"}* />  

          jsp:标签的前缀,说明是jsp内置的标签,

          elements:行为的名称,

          attribute=value:使用键值对来编写属性

          *:能指定0个或多个属性对

    <jsp:include />行为

       include行为用于运行时包含某个文件,如果被包含的文件为JSP程序,则先会执行JSP程序,然后在把执行的结果包含进来。 作用是跟include指令一样的,唯一的区别就在于,include指令是将被包含的文件的源码加入到了本JSP程序中,然后在进行编译,属于静态包含,而include行为只是将被包含的文件的运行结果包含进自己。属于动态包含

          

    Java bean行为

       是一组与Java Bean 相关的行为,包括useBean行为、setProperty行为、getProperty行为等

       Java Bean就是普通的Java类,也被称为POJO,只有私有的属性与对应的getter方法和setter方法,注意其中当私有的属性为boolean类型时,习惯上一般把getter方法写成isXxx();而不是getXxx();

       useBean行为  

          <jsp:useBean id="beanObject" class="className" scope="Value">  作用:在jsp中定义一个java bean对象,   

             id:指明Java Bean对象的名称,JSP中可以使用该名称引用该Java Bean对象,相当于给new出来的对象取一个变量名,

             class:Java Bean类的全名

             scope:该java bean对象的作用范围,可以写的就四个,也就是JSP的四大作用域,page、request、session、application

                  page:只能在当前JSP页面使用,如果不在JSP页面,那么就会失效

                  request:这个前面学过,A页面请求转发到B页面,那么使用的是同一个request,那么A,B页面都算是request的作用域,也就是通过请求转发的页面都是其作                       用域

                  session:该作用域在一个web项目下任何位置应该读访问的到,只要cookie不关闭,并且cookie设置  的访问路径为"/",

                  application:其实就是Servlet中的servletContext,服务器下的所有项目都能访问到。

       setProperty行为

          <jsp:setProperty name="beanName" property="propertyName" value="">

            对Java Bean对象进行属性的设置

            name:java bean对象的名称,也就是在useBean行为中的id

            property:对象中的属性名,

            value:要对其属性进行赋值的值

              

       getProperty行为

          <jsp:getProperty name="beanName" property="propertyName" />

            获取JavaBean对象的某个属性值

            name:java bean 对象的名称,也就是在useBean行为中的id

            property:对象的属性名

      例子:  javabean:User.java  NewFile.jsp

      User.java

 View Code

      NewFile.jsp

 View Code

      可以查看NewFile.jsp变为servlet后的源代码,看看我们写的javabean行为会被转换为何种语句

          

      这里出现了一个JSP九大内置对象中的一个,pageContext。现在简单提一句,pageContext就是JSP页面的管理者(上下文),其中的getAttribute(name,scope)方法是获取指定作用域中的数据的,如果getAttribute(name)方法的话,默认是对page作用域进行操作,findAttribute(name)依次从page、request、session、application获得内容。 

      在第一个红框中,就代表中我们的useBean行为,其中进行了一次判断,就是如果在page作用域中找不到user这个对象,那么就创建一个新的,否则就使用找到的这个user对象,

      第二个红框中,代表着我们的setProperty行为,先找到user对象,然后在对其属性进行赋值

      第三个红框中,代表着我们的getProperty行为,也是先找到user对象,然后在获取其属性的值。

 

      注意:对于javabean行为来说,有一个特点的地方,就是当请求过来的参数对应javabean的属性时,可以为其一次性设置所有的值

          <jsp:setProperty name="user" property="*" /> //设置user的所有属性,属性值从request中自动取得,*代表所有属性。

        

    <jsp:forward />行为

      实现请求转发功能,Servlet中通过request.getRequestDispatcher("someServlet").forward(request,response);而在JSP中也能够实现相同的功能,只不过用的是<jsp:forward />行为,实际上forward行为就是对其进行了封装。

      格式:

        <jsp:forward page="someServlet">

           <jsp:param name="param1" value="value1"/>

           <jsp:param name="param2" value="value2"/>

        </jsp:forward>

        page:需要跳转到的页面或者servlet、 <jsp:param/>参数行为,带一些参数过去,name、value是以键值对的形式带过去的

      例如:

         NewFile.jsp

               

         MyServlet.java

           

         访问:http://localhost:8080/test01/NewFile.jsp

           

          浏览器地址栏没有改变,说明是请求转发

         NewFile_jsp.java

          

          使用return的好处是执行完上面的转发,就直接return,没有必要在执行下面的代码了,对参数使用了URLEncode进行编码,说明该<jsp:param/>可以直接传递中文,但是前提是要设置request.setCharacterEncoding("UTF-8");为什么这样做,看上面框起来中的代码。

 

    <jsp:directive/>行为

       directive行为,就相当于JSP指令,比如<jsp:directive.page/>相当于<%@ page %>指令,等等其它指令是一样的书写格式。        

 

五、JSP隐藏的九大内置对象和四大作用域

     之前那么一大段内容,就是为了讲解什么是JSP,JSP中的内容是怎么样的,到这里应该知道的差不多了, 但我们还要深入了解一些东西,我们知道JSP中的内容就只有两种,模版数据,和元素,元素就包括了指令呀,脚本呀,标签(行为)呀,脚本会慢慢被标签全部代替,也就是说JSP中基本上不会嵌入Java代码,但是我们也知道JSP会转换为servlet,在Servlet中,输出数据时,都需要通过response.getWrite();但是在JSP中,直接使用out对象进行输出,为什么呢?这就是因为out为JSP的一个隐藏对象,JSP中内置了9个隐藏对象,使得JSP比Servlet使用起来更简单,更方便,

    page、config、application、request、response、session、out、exception、pageContext

      page:page对象代表当前JSP页面,是当前JSP编译后的Servlet类的对象。相当于this。

      config:标识Servlet配置,类型:ServletConfig,api跟Servlet中的ServletConfig对象是一样的,能获取该servlet的一些配置信息,能够获取ServletContext

      application:标识web应用上下文,类型:ServletContext,详情就看Servlet中的ServletContext的使用

      request:请求对象,  类型:httpServletRequest

      response:响应对象  类型:httpServletResponse

      session:表示一次会话,在服务器端记录用户状信息的技术

      out:输出响应体 类型:JspWriter

      exception 表示发生异常对象,类型 Throwable,在上面我们介绍page指令中的一个errorPage属性时就有说到他

      pageContext:表示 jsp页面上下文(jsp管理者) 类型:PageContext

     标记了红色的对象就是JSP独有的,其他的都是Servlet中的老东西。

      

      在这个由jsp转换为servlet的文件中,只能看到8个内置对象,少了exception对象,因为我们在将page指令时,说过一个isErrorPage属性,默认是false,被关闭了,所以其中并没有exception对象。

     JSP的四大作用域:page、request、session、application

        这四大作用域,其实就是其九大内置对象中的四个,为什么说他们也是JSP的四大作用域呢?因为这四个对象都能存储数据,比如request.setAttribute()注意和request.setParameter()区分开来,一个是存储在域中的、一个是请求参数,session.setAttribute()、application其实就是SerlvetContext,自然也有setAttribute()方法。而page作用域的操作就需要依靠pageContext对象来进行了。在上面我们也有提到JSP的四大作用域,

        page作用域:代表变量只能在当前页面上生效

        request:代表变量能在一次请求中生效,一次请求可能包含一个页面,也可能包含多个页面,比如页面A请求转发到页面B

        session:代表变量能在一次会话中生效,基本上就是能在web项目下都有效,session的使用也跟cookie有很大的关系。一般来说,只要浏览器不关闭,cookie就会一直生效,cookie生效,session的使用就不会受到影响。

        application:代表变量能一个应用下(多个会话),在服务器下的多个项目之间都能够使用。比如baidu、wenku等共享帐号。

     out对象:

        类型:JspWriter

        jsp 输出底层使用 response.getWriter();什么意思呢?这里就要讲解一下JSP缓存和Servlet缓存了,输出的过程是这样的

                 

        JSP页面转换为Servlet后,使用的out对象是JspWriter类型的,所以是会先将要发送的数据存入JSP输出缓存中,然后,等JSP输出缓存满了在自动刷新到servlet输出缓存,等serlvet输出缓存满了,或者程序结束了,就会将其输出到浏览器上。除非手动out.flush()。

        验证servlet输出缓存和JSP输出缓存和我们上面所说的是正确的。

            

             

          分析:如果按没有jsp缓存和servlet缓存的话,输出的结果应该是aaaabbbbcccc,但是输出的却是bbbbaaaacccc,为什么呢?按照我们上面所说的原理进行分析,out对象是先将其输出到JSP缓存中,所以aaaa加入了jsp缓存,而response.getWriter().print("bbbb")是直接将bbbb输出到servlet缓存中,然后又使用out对象将cccc输出到jsp缓存,到程序结束,servlet缓存中有bbbb,然后jsp会将缓存中的内容就刷新到servlet缓存中,serlvet就是bbbbaaaacccc了,然后到浏览器也就得到我们的输出结果了。如果在12行将注释去掉,那么输出的结果又会是什么呢?答案就是aaaabbbbcccc,过程自行分析。

            

 

     pageContext对象:重点

        这个功能就比较强大了,比较牛逼,基本上什么他都有,因为是它是JSP页面的管理者(上下文),所以JSP中的内置对象呀,它统统能够获得,下面介绍它的api。

        1、获得其它八大内置对象 getXxx()

          pageContext.getOut();  //获得out对象

          pageContext.getApplication();  //获得application对象

          等等....

        2、对作用域的属性进行操作(四大作用域)

          对默认作用域的属性进行操作。page

          pageContext.getAttribute(name);  //获得page作用域数据

          pageContext.setAttribute(name,value);  //给page作用域设置内容

          pageContext.removeAttribute(name);  //给page作用域移除内容

        3、对指定作用域的属性进行操作

          getAttribute(name,scope);  //获得 指定作用域中的数据

          setAttribute(name,value);  //给指定作用域设置内容

          removeAttribute(name ,scope)  移除指定作用域的内容(page/request/session/application)

        4、提供作用域常量

          PageContext.PAGE_SCOPE  page

          PageContext.REQUEST_SCOPE  request      

          PageContext.SESSION_SCOPE  response

          PageContext.APPLICATION_SCOPE  application

        5、一次获得指定名称内容

          findAttribute(name);  //依次从page、request、session、application 获得内容

 

     response对象:

        就是响应对象,、如果不了解就看看讲解request和response的这一章节的内容

 

     config对象:

        类型:ServletConfig

        能够获取servlet的初始化参数,获取servletContext对象,获取servletName

        api详情请看讲解servlet这一章节

 

     exception异常对象:

        包含了异常的信息

        使用它,必须结合page指令中的isErrorPage属性和errorPage属性。

        exception.jsp  抛异常的一个NullPointException,并且跳转到error.jsp错误显示页面  errorPage属性的意思是如果发生未捕捉到的异常,将会跳转到error.jsp页面

            

        error.jsp  isErrorPage属性说明该页面是一个错误显示页面,则可以使用exception对象

            

        访问http://localhost:8080/test01/exception.jsp

            

六、总结

    通过上面一大堆一大堆的学习,我们应该知道这些东西

    1、什么是JSP?

      JSP本质上就是一个servlet,因为servlet输出html太麻烦了,所以就有了JSP,JSP就是专门用来书写html的,当然其中也能写java代码。

    2、JSP的内容包括什么?

      模版数据和元素。其中元素有包括脚本(java代码)、指令(页面属性)、和行为(标签,为了JSP中不嵌入那么多java代码衍生的)

    3、JSP中九大内置对象是哪九个?

      九大内置对象,page、config、appliction、request、response、session、out、exception、pageContext

    4、九大内置对象和servlet中对象的关系

      page就是jsp转换为servletservlet对象本身,也就是this

      config -- Servlet中的servletConfig

      application -- Servlet中的ServletContext

      request  -- Servlet中的request

      response  -- Servlet中的response

      session  -- Servlet中的session    

      out  -- JspWriter

      exception  -- 异常对象

      pageContext  -- 表示 jsp页面上下文(jsp管理者) 类型:PageContext,

        其中pageContext对象最牛逼,有了他就拥有了天下,哈哈~

   5、JSP中的四大作用域。

      page、request、session、application

      其中操作page域中属性需要借助pageContext对象。

   6、JSP中还有其他两大块内容

      一个是EL表达式,很重要

    这也是属于JSP范围内的知识,使用EL表达式,能更好的使用JSP中的各种内置对象和作用域,说点闲话,马上要出去实习了,有点恐慌,可能这是马上要出去工作的学生的通病,继续努力把,兵来将挡水来土掩,

           

一、EL表达式

    JSP中可以使用EL表达式,EL表达式是用"${}"括起来的脚本,用来更方便地读取对象,EL表达式写在JSP的HTML代码中,而不能写在"<%%>"引起的JSP脚本中,现在就来了解一下,EL表达式是如何来替代JSP脚本或者JSP行为的。

    EL表达式有11个内置对象。

       pageScope、requestScope、sessionScope、applicationScope、pageContext、param、paramValues、header、headerValues、cookie、initParam

    pageScope、requestScope、sessionScope、applicationScope代表四个作用域对象

    pageContext  表示的是JSP中内置对象pageContext,能获取request等其他JSP八大内置对象  

    param  表示一个请求参数  ${param.username}  等效  request.getParameter("username");

    paramValues  表示一组请求参数  ${paramValues.loves}  等效request.getParameterValues("loves");  提交喜爱这种多选框    

    header  表示一个请求头  ${header.referer}  等效request.getHeader("referer");

    headerValues  表示一组请求头  ${header.cookie}  等效 request.getHeaders("cookie");  获取的请求头参数中的内容是一组内容,比如cookie就有可以是多个cookie一起传过来

    cookie  获得cookie对象

    initPatam  web项目初始化参数,servletContext.getInitParameter("xxx");

    

    还有一种特殊的用法,直接获取对象变量,

      ${user.username}

       user为User的一个实例对象,并且存放在page作用域中,上面这句代码的意思是,依次从page、request、session、application作用域查找user对象,直到找到为止,底层使用的是pageContext.findAttribute(); 是一样的效果。

 

    实例讲解:

        

      

    总结:

      EL表达式比较简单,使用它的目的是为了减少JSP脚本,尽量不要在HTML中嵌入Java代码,显的很混乱,而在HTML中使用EL表达式,就比较好来获取JSP中各种对象,获取四大作用域中的值,

      如果要获取四大作用域中的数据,则可以使用${}、${pageScope.xxx} 

      如果想要获取请求参数,则使用param或paramValues

      如果想要获取请求头中的一些信息,获取想要获取Servlet的一些对象,比如request、session等,可以使用pageContext来获取request对象,然后在获取所需要的信息,或者直接使用header对象来获取头信息

      如果想获取web初始化参数,则使用initPatam

 

      el表达式的运算就不讲解了,很简单,基本上能用的都可以用。

  

      最主要的是要记得EL中有哪11个内置对象,知道了他们就知道了EL可以获取哪些信息。

转载:

https://www.cnblogs.com/whgk/p/6427759.html

 

posted @ 2019-01-07 10:28  悦文  阅读(396)  评论(0编辑  收藏  举报