EL 全名为Expression Language。EL主要做用: java
一、获取数据 web
EL表达式主要用于替换JSP页面中的脚本表达式<%= %>,以从各类类型的web域 中检索java对象、获取数据。(某个web域 中的对象,访问javabean的属性、访问list集合、访问map集合、访问数组)数组
二、执行运算 tomcat
利用EL表达式能够在JSP页面中执行一些基本的关系运算、逻辑运算和算术运算,以在JSP页面中完成一些简单的逻辑运算。${user==null}服务器
三、获取web开发经常使用对象 cookie
EL 表达式定义了一些隐式对象,利用这些隐式对象,web开发人员能够很轻松得到对web经常使用对象的引用,从而得到这些对象中的数据。session
四、调用Java方法 app
EL表达式容许用户开发自定义EL函数,以在JSP页面中经过EL表达式调用Java类的方法。less
使用EL表达式获取数据语法:“${标识符}” jsp
EL表达式语句在执行时,会调用pageContext.findAttribute方法,用标识符为关键字,分别从page、request、session、application四个域中查找相应的对象,找到则返回相应对象,找不到则返回”” (注意,不是null,而是空字符串)。
EL表达式能够很轻松获取JavaBean的属性,或获取数组、Collection、Map类型集合的数据。
(1)关系运算
(2)逻辑运算
(3)empty运算
empty运算符:检查对象是否为null(空), 一种是null,没有建立;二是建立了,里面没有东西,是空的。
eg: ${!empty(list)} 判断list对象是否为空或null
(4)二元表达式:${user!=null?user.name :”“}
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}。
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 { //一、接收参数 String userName = request.getParameter("username"); /** * 二、直接跳转回/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参数的值
EL表达式语法容许开发人员开发自定义函数,以调用Java类的方法。语法:${prefix:method(params)}
在EL表达式中调用的只能是Java类的静态方法,这个Java类的静态方法须要在TLD文件中描述,才能够被EL表达式调用。
EL自定义函数用于扩展EL表达式的功能,可让EL表达式完成普通Java程序代码所能完成的功能。
通常来讲, EL自定义函数开发与应用包括如下三个步骤:
编写一个Java类的静态方法
编写标签库描述符(tld)文件,在tld文件中描述自定义函数。
在JSP页面中导入和使用自定义函数
不作重点考虑
EL表达式是JSP 2.0规范中的一门技术 。所以,若想正确解析EL表达式,需使用支持Servlet2.4/JSP2.0技术的WEB服务器。
注意:有些Tomcat服务器如不能使用EL表达式
(1)升级成tomcat6
(2)在JSP中加入<%@ page isELIgnored="false" %>
因为在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"%>
解决办法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