EL表达式和EL函数库

一、EL表达式简介

  EL 全名为Expression Language。EL主要作用: 

1、获取数据 

    EL表达式主要用于替换JSP页面中的脚本表达式<%= %>,以从各种类型的web域 中检索java对象、获取数据。(某个web域 中的对象,访问javabean的属性、访问list集合、访问map集合、访问数组)

2、执行运算 

    利用EL表达式可以在JSP页面中执行一些基本的关系运算、逻辑运算和算术运算,以在JSP页面中完成一些简单的逻辑运算。${user==null}

3、获取web开发常用对象 

    EL 表达式定义了一些隐式对象,利用这些隐式对象,web开发人员可以很轻松获得对web常用对象的引用,从而获得这些对象中的数据。

4、调用Java方法 

    EL表达式允许用户开发自定义EL函数,以在JSP页面中通过EL表达式调用Java类的方法。


1.1 EL获取数据

    使用EL表达式获取数据语法:“${标识符}” 

    EL表达式语句在执行时,会调用pageContext.findAttribute方法,用标识符为关键字,分别从page、request、session、application四个域中查找相应的对象,找到则返回相应对象,找不到则返回”” (注意,不是null,而是空字符串)。

    EL表达式可以很轻松获取JavaBean的属性,或获取数组CollectionMap类型集合的数据。


1.2 EL执行表达式

(1)关系运算

EL表达式和EL函数库_第1张图片

(2)逻辑运算

EL表达式和EL函数库_第2张图片

(3)empty运算

    empty运算符:检查对象是否为null(空), 一种是null,没有创建;二是创建了,里面没有东西,是空的。

    eg:    ${!empty(list)}    判断list对象是否为空或null

(4)二元表达式:${user!=null?user.name :”“} 


1.3 EL获取web开发常用对象

    EL表达式语言中定义了11个隐含对象(包括之前的9大内置对象中的5个,另外新增了param、paramValues、header、 headerValues、cookie和web初始化参数initParam),使用这些隐含对象可以很方便地获取web开发中的一些常见对象,并读取这些对象的数据。 

语法:${隐式对象名称}    获得对象的引用

序号 name(隐含对象名称) 描述
1 pageContext 对应于JSP页面的pageContext对象
2 pageScope 代表page域中用于保存属性的Map对象
3 requestScope 代表request域中用于保存属性的Map对象
4 sessionScope 代表session域中用于保存属性的Map对象
5 applicationScope 代表application域中用于保存属性的Map对象
6 param 表示一个保存所有请求参数的Map对象
7 paramValues
表示一个保存所有请求参数的Map对象,对于某个请求参数,返回的是一个与之对应的String[]
8 header 表示一个保存了所有http请求头字段的Map对象
9 headerValues 表示一个保存了所有http请求头字段的Map对象,对于某个请求参数,返回的是一个与之对应的String[]
10 cookie 表示一个保存了所有cookie的Map对象
11 iniParam 表示了一个保存了所有web应用初始化参数的Map对象

例如:

<!-- http://localhost:8080/JavaWeb_EL_Study/ELDemo03.jsp?name=aaa  -->
<!-- 此表达式经常用在数据回显上 -->
${param.name}

<!-- http://localhost:8080/JavaWeb_EL_Study/ELDemo03.jsp?like=aaa&like=bbb -->
${paramValues.like[0]}  
${paramValues.like[1]}

<%-- ${header.Accept-Encoding} 这样写会报错,测试headerValues时,如果头里面有“-” ,例Accept-Encoding,则要headerValues[“Accept-Encoding”] --%>


<!-- 从cookie隐式对象中根据名称获取到的是cookie对象,要想获取值,还需要.value -->
${cookie.JSESSIONID.value}  //保存所有cookie的map

    测试cookie时,例${cookie.key}取的是cookie对象,如访问cookie的名称和值,须${cookie.key.name}或${cookie.key.value}。

1.3.1 数据回显

eg:

servlet

import java.io.IOException;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

public class RegisterServlet extends HttpServlet {
    /* 
     * 处理用户注册的方法
     */
    public void doGet(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {
        //1、接收参数
        String userName = request.getParameter("username");
        /**
         * 2、直接跳转回/ELDemo03.jsp页面,
         * 没有使用request.setAttribute("userName", userName)将userName存储到request对象中
         * 但是在ELDemo03.jsp页面中可以使用${param.username}获取到request对象中的username参数的值
         */
        request.getRequestDispatcher("/ELDemo03.jsp").forward(request, response);
    }

    public void doPost(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {
        doGet(request, response);
    }
}

   jsp

<!-- 利用param可以获取回显数据 -->
<p>${param.username}</p>

 注:直接跳转回/ELDemo03.jsp页面, 没有使用request.setAttribute("userName", userName)将userName存储到request对象中,但是在ELDemo03.jsp页面中可以使用${param.username}可以获取到request对象中的username参数的值


1.4 EL调用Java方法

  • EL表达式语法允许开发人员开发自定义函数,以调用Java类的方法。语法:${prefix:method(params)} 

  • 在EL表达式中调用的只能是Java类的静态方法,这个Java类的静态方法需要在TLD文件中描述,才可以被EL表达式调用。 

  • EL自定义函数用于扩展EL表达式的功能,可以让EL表达式完成普通Java程序代码所能完成的功能。


1.5 EL Function开发步骤

 一般来说, EL自定义函数开发与应用包括以下三个步骤: 

  • 编写一个Java类的静态方法 

  • 编写标签库描述符(tld)文件,在tld文件中描述自定义函数。 

  • 在JSP页面中导入和使用自定义函数

不做重点考虑


1.6 EL注意事项

  EL表达式是JSP 2.0规范中的一门技术 。因此,若想正确解析EL表达式,需使用支持Servlet2.4/JSP2.0技术的WEB服务器。 

注意:有些Tomcat服务器如不能使用EL表达式 

(1)升级成tomcat6 

(2)在JSP中加入<%@ page isELIgnored="false" %>


1.7 EL保留关键字

EL表达式和EL函数库_第3张图片


二、EL函数库

    由于在JSP页面中显示数据时,经常需要对显示的字符串进行处理,SUN公司针对于一些常见处理定义了一套EL函数库供开发者使用。 

    这些EL函数在JSTL开发包中进行描述,因此在JSP页面中使用SUN公司的EL函数库,需要导入JSTL开发包,并在页面中导入EL函数库

(1)导入相关的jstl包

<dependency>
  <groupId>jstl</groupId>
  <artifactId>jstl</artifactId>
  <version>1.2</version>
</dependency>

(2)jsp页面引用

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


三、EL表达式不能解析

解决办法1:

当web.xml里是dtd时

<!DOCTYPE web-app PUBLIC
 "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN"
 "http://java.sun.com/dtd/web-app_2_3.dtd" >
 <web-app>
 </web-app>

可以在jsp页面中添加:

<%@ page isELIgnored="false" %>

解决办法2:

也可以将上述web.xml里的dtd改为以下xsd

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://java.sun.com/xml/ns/javaee"
         version="2.5"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">
</web-app>


The isELIgnored Attribute 

• Format 

– <%@ page isELIgnored="false" %> 

– <%@ page isELIgnored="true" %> 

Purpose 

– To control whether the JSP 2.0 Expression Language 

(EL) is ignored (true) or evaluated normally (false). 

• Notes 

– If your web.xml specifies servlets 2.3 (corresponding to 

JSP 1.2) or earlier, the default is true 

• But it is still legal to change the default—you are permitted 

to use this attribute in a JSP-2.0-compliant server 

regardless of the web.xml version. 

– If your web.xml specifies servlets 2.4 (corresponding to 

JSP 2.0) or earlier, the default is false


你可能感兴趣的:(EL表达式和EL函数库)