EL全稱 Expression Language(表達式語言),是jsp2.0最重要的特性之一,可以利用EL表達式來訪問應用程序中的數據,來消除jsp頁面中的java腳本。
el表達式的語法
expression例如x+y可以寫成{x+y}
el中的關鍵字
以下是el中的關鍵字,他們不能用做標識符:
and,eq,gt,true,instanceof,or,ne,le,false,empty,not,lt,ge,null,div,mod
一、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表達式語句在執行時,會調用pageContext.findAttribute方法,用標識符為關鍵字,分別從page、request、session、application四個域中查找相應的對象,找到則返回相應對象,找不到則返回”” (注意,不是null,而是空字符串)。
EL表達式可以很輕松獲取JavaBean的屬性,或獲取數組、Collection、Map類型集合的數據
el表達式獲取數據范例:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
|
<%@ page language= "java" import = "java.util.*" pageEncoding= "UTF-" %> <% @taglib uri= "http://java.sun.com/jsp/jstl/core" prefix= "c" %> <% @page import = "me.gacl.domain.Person" %> <% @page import = "me.gacl.domain.Address" %> <!DOCTYPE HTML> <html> <head> <title>el表達式獲取數據</title> </head> <body> <% request.setAttribute( "name" , "孤傲蒼狼" ); %> <%--${name}等同于pageContext.findAttribute( "name" ) --%> 使用EL表達式獲取數據:${name} <hr> <!-- 在jsp頁面中,使用el表達式可以獲取bean的屬性 --> <% Person p = new Person(); p.setAge(); request.setAttribute( "person" ,p); %> 使用el表達式可以獲取bean的屬性:${person.age} <hr> <!-- 在jsp頁面中,使用el表達式可以獲取bean中的。。。。。。。。。的屬性 --> <% Person person = new Person(); Address address = new Address(); person.setAddress(address); request.setAttribute( "person" ,person); %> ${person.address.name} <hr> <!-- 在jsp頁面中,使用el表達式獲取list集合中指定位置的數據 --> <% Person p = new Person(); p.setName( "孤傲蒼狼" ); Person p = new Person(); p.setName( "白虎神皇" ); List<Person> list = new ArrayList<Person>(); list.add(p); list.add(p); request.setAttribute( "list" ,list); %> <!-- 取list指定位置的數據 --> ${list[].name} <!-- 迭代List集合 --> <c:forEach var= "person" items= "${list}" > ${person.name} </c:forEach> <hr> <!-- 在jsp頁面中,使用el表達式獲取map集合的數據 --> <% Map<String,String> map = new LinkedHashMap<String,String>(); map.put( "a" , "aaaaxxx" ); map.put( "b" , "bbbb" ); map.put( "c" , "cccc" ); map.put( "" , "aaaa" ); request.setAttribute( "map" ,map); %> <!-- 根據關鍵字取map集合的數據 --> ${map.c} ${map[ "" ]} <hr> <!-- 迭代Map集合 --> <c:forEach var= "me" items= "${map}" > ${me.key}=${me.value}<br/> </c:forEach> <hr> </body> </html> |
運行效果如下:
1.2、執行運算
語法:${運算表達式},EL表達式支持如下運算符:
1、關系運算符
2、邏輯運算符:
3、empty運算符:檢查對象是否為null(空)
4、二元表達式:${user!=null?user.name :""}
5、[ ] 和 . 號運算符
使用EL表達式執行運算范例:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
|
<%@ page language= "java" import = "java.util.*" pageEncoding= "UTF-" %> <% @taglib uri= "http://java.sun.com/jsp/jstl/core" prefix= "c" %> <% @page import = "me.gacl.domain.User" %> <!DOCTYPE HTML> <html> <head> <title>el表達式運算符</title> </head> <body> <h>el表達式進行四則運算:</h> 加法運算:${+}<br/> 減法運算:${-}<br/> 乘法運算:${*}<br/> 除法運算:${/}<br/> <h>el表達式進行關系運算:</h> <%--${user == null }和 ${user eq null }兩種寫法等價--%> ${user == null }<br/> ${user eq null }<br/> <h>el表達式使用empty運算符檢查對象是否為 null (空)</h> <% List<String> list = new ArrayList<String>(); list.add( "gacl" ); list.add( "xdp" ); request.setAttribute( "list" ,list); %> <%--使用empty運算符檢查對象是否為 null (空) --%> <c: if test= "${!empty(list)}" > <c:forEach var= "str" items= "${list}" > ${str}<br/> </c:forEach> </c: if > <br/> <% List<String> emptyList = null ; %> <%--使用empty運算符檢查對象是否為 null (空) --%> <c: if test= "${empty(emptyList)}" > 對不起,沒有您想看的數據 </c: if > <br/> <h>EL表達式中使用二元表達式</h> <% session.setAttribute( "user" , new User( "孤傲蒼狼" )); %> ${user== null ? "對不起,您沒有登陸 " : user.username} <br/> <h>EL表達式數據回顯</h> <% User user = new User(); user.setGender( "male" ); //數據回顯 request.setAttribute( "user" ,user); %> <input type= "radio" name= "gender" value= "male" ${user.gender== 'male' ? 'checked' : '' }>男 <input type= "radio" name= "gender" value= "female" ${user.gender== 'female' ? 'checked' : '' }>女 <br/> </body> </html> |
運行結果如下:
1.3、獲得web開發常用對象
EL表達式語言中定義了11個隱含對象,使用這些隱含對象可以很方便地獲取web開發中的一些常見對象,并讀取這些對象的數據。
語法:${隱式對象名稱}:獲得對象的引用
測試EL表達式中的11個隱式對象:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
|
<%@ page language= "java" import= "java.util.*" pageEncoding= "UTF-" %> <!DOCTYPE HTML> <html> <head> <title>el隱式對象</title> </head> <body> <br/>---------------、pageContext對象:獲取JSP頁面中的pageContext對象------------------------<br/> ${pageContext} <br/>---------------、pageScope對象:從page域(pageScope)中查找數據------------------------<br/> <% pageContext.setAttribute( "name" , "孤傲蒼狼" ); //map %> ${pageScope.name} <br/>---------------、requestScope對象:從request域(requestScope)中獲取數據------------------------<br/> <% request.setAttribute( "name" , "白虎神皇" ); //map %> ${requestScope.name} <br/>---------------、sessionScope對象:從session域(sessionScope)中獲取數據------------------------<br/> <% session.setAttribute( "user" , "xdp" ); //map %> ${sessionScope.user} <br/>---------------、applicationScope對象:從application域(applicationScope)中獲取數據------------------------<br/> <% application.setAttribute( "user" , "gacl" ); //map %> ${applicationScope.user} <br/>--------------、param對象:獲得用于保存請求參數map,并從map中獲取數據------------------------<br/> <!-- http: //localhost:/JavaWeb_EL_Study_/ELDemo.jsp?name=aaa --> ${param.name} <!-- 此表達式會經常用在數據回顯上 --> <form action= "${pageContext.request.contextPath}/servlet/RegisterServlet" method= "post" > <input type= "text" name= "username" value= "${param.username}" > <input type= "submit" value= "注冊" > </form> <br/>--------------、paramValues對象:paramValues獲得請求參數 //map{"",String[]}------------------------<br/> <!-- http: //localhost:/JavaWeb_EL_Study_/ELDemo.jsp?like=aaa&like=bbb --> ${paramValues.like[]} ${paramValues.like[]} <br/>--------------、header對象:header獲得請求頭------------------------<br/> ${header.Accept}<br/> <%--${header.Accept-Encoding} 這樣寫會報錯 測試headerValues時,如果頭里面有“-” ,例Accept-Encoding,則要headerValues[“Accept-Encoding”] --%> ${header[ "Accept-Encoding" ]} <br/>--------------、headerValues對象:headerValues獲得請求頭的值------------------------<br/> <%--headerValues表示一個保存了所有http請求頭字段的Map對象,它對于某個請求參數,返回的是一個string[]數組 例如:headerValues.Accept返回的是一個string[]數組 ,headerValues.Accept[]取出數組中的第一個值 --%> ${headerValues.Accept[]}<br/> <%--${headerValues.Accept-Encoding} 這樣寫會報錯 測試headerValues時,如果頭里面有“-” ,例Accept-Encoding,則要headerValues[“Accept-Encoding”] headerValues[ "Accept-Encoding" ]返回的是一個string[]數組,headerValues[ "Accept-Encoding" ][]取出數組中的第一個值 --%> ${headerValues[ "Accept-Encoding" ][]} <br/>--------------、cookie對象:cookie對象獲取客戶機提交的cookie------------------------<br/> <!-- 從cookie隱式對象中根據名稱獲取到的是cookie對象,要想獲取值,還需要.value --> ${cookie.JSESSIONID.value} //保存所有cookie的map <br/>--------------、initParam對象:initParam對象獲取在web.xml文件中配置的初始化參數------------------------<br/> <%-- <!-- web.xml文件中配置初始化參數 --> <context-param> <param-name>xxx</param-name> <param-value>yyyy</param-value> </context-param> <context-param> <param-name>root</param-name> <param-value>/JavaWeb_EL_Study_</param-value> </context-param> --%> <%--獲取servletContext中用于保存初始化參數的map --%> ${initParam.xxx}<br/> ${initParam.root} </body> </html> |
RegisterServlet的代碼如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
|
package me.gacl.web.controller; 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"); /** * 、直接跳轉回/ELDemo.jsp頁面,沒有使用request.setAttribute("userName", userName)將userName存儲到request對象中 * 但是在ELDemo.jsp頁面中可以使用${param.username}獲取到request對象中的username參數的值 */ request.getRequestDispatcher( "/ELDemo.jsp" ).forward(request, response); } public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { doGet(request, response); } } |
測試結果如下:
注意:
測試header和headerValues時,如果頭里面有“-” ,例Accept-Encoding,則要header["Accept-Encoding"]、headerValues["Accept-Encoding"]
測試cookie時,例${cookie.key}取的是cookie對象,如訪問cookie的名稱和值,須${cookie.key.name}或${cookie.key.value}
1.4、使用EL調用Java方法
EL表達式語法允許開發人員開發自定義函數,以調用Java類的方法。語法:${prefix:method(params)}
在EL表達式中調用的只能是Java類的靜態方法,這個Java類的靜態方法需要在TLD文件中描述,才可以被EL表達式調用。
EL自定義函數用于擴展EL表達式的功能,可以讓EL表達式完成普通Java程序代碼所能完成的功能。
1.5、EL Function開發步驟
一般來說, EL自定義函數開發與應用包括以下三個步驟:
1、編寫一個Java類的靜態方法
2、編寫標簽庫描述符(tld)文件,在tld文件中描述自定義函數。
3、在JSP頁面中導入和使用自定義函數
示例:開發對html標簽進行轉義的el function
1、編寫html轉義處理工具類,工具類中添加對html標簽進行轉義的靜態處理方法,如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
|
package me.gacl.util; /** * @ClassName: HtmlFilter * @Description: html轉義處理工具類 * @author: 孤傲蒼狼 * @date: -- 上午:: * */ public class HtmlFilter { /** * @Method: filter * @Description: 靜態方法,html標簽轉義處理 * @Anthor:孤傲蒼狼 * * @param message 要轉義的內容 * @return 轉義后的內容 */ public static String filter(String message) { if (message == null ) return ( null ); char content[] = new char [message.length()]; message.getChars(, message.length(), content, ); StringBuffer result = new StringBuffer(content.length + ); for ( int i = ; i < content.length; i++) { switch (content[i]) { case '<' : result.append( "<" ); break ; case '>' : result.append( ">" ); break ; case '&' : result.append( "&" ); break ; case '"' : result.append( "" "); break ; default : result.append(content[i]); } } return (result.toString()); } } |
2、在WEB-INF目錄下編寫標簽庫描述符(tld)文件,在tld文件中描述自定義函數
elFunction.tld的代碼如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
|
<?xml version= "." encoding= "UTF-" ?> <taglib version= "." xmlns= "http://java.sun.com/xml/ns/jee" xmlns:xsi= "http://www.w.org//XMLSchema-instance" xsi:schemaLocation= "http://java.sun.com/xml/ns/jee web-jsptaglibrary__.xsd" > <tlib-version>.</tlib-version> < short -name>EL Function</ short -name> <!-- 自定義EL函數庫的引用URI, 在JSP頁面中可以這樣引用:<% @taglib uri= "/ELFunction" prefix= "fn" %> --> <uri>/ELFunction</uri> <!--<function>元素用于描述一個EL自定義函數 --> <function> <description>html標簽轉義處理方法</description> <!--<name>子元素用于指定EL自定義函數的名稱--> <name>filter</name> <!--<function- class >子元素用于指定完整的Java類名--> <function- class >me.gacl.util.HtmlFilter</function- class > <!--<function-signature>子元素用于指定Java類中的靜態方法的簽名, 方法簽名必須指明方法的返回值類型及各個參數的類型,各個參數之間用逗號分隔。--> <function-signature>java.lang.String filter(java.lang.String)</function-signature> </function> </taglib> |
3、在JSP頁面中導入和使用自定義函數
1
2
3
4
5
6
7
8
9
10
11
12
13
|
<%@ page language= "java" import = "java.util.*" pageEncoding= "UTF-" %> <%--引入EL自定義函數庫 --%> <% @taglib uri= "/ELFunction" prefix= "fn" %> <!DOCTYPE HTML> <html> <head> <title>使用EL調用Java方法</title> </head> <body> <%--使用EL調用filter方法--%> ${fn:filter( "<a href=''>點點</a>" )} </body> </html> |
運行結果如下:
1.6、開發EL Function注意事項
編寫完標簽庫描述文件后,需要將它放置到<web應用>\WEB-INF目錄中或WEB-INF目錄下的除了classes和lib目錄之外的任意子目錄中。
TLD文件中的<uri> 元素用指定該TLD文件的URI,在JSP文件中需要通過這個URI來引入該標簽庫描述文件。
<function>元素用于描述一個EL自定義函數,其中:
<name>子元素用于指定EL自定義函數的名稱。
<function-class>子元素用于指定完整的Java類名,
<function-signature>子元素用于指定Java類中的靜態方法的簽名,方法簽名必須指明方法的返回值類型及各個參數的類型,各個參數之間用逗號分隔。
1.7、EL注意事項
EL表達式是JSP 2.0規范中的一門技術 。因此,若想正確解析EL表達式,需使用支持Servlet2.4/JSP2.0技術的WEB服務器。
注意:有些Tomcat服務器如不能使用EL表達式
(1)升級成tomcat6
(2)在JSP中加入<%@ page isELIgnored="false" %>
1.8、EL表達式保留關鍵字
所謂保留字的意思是指變量在命名時,應該避開上述的名字,以免程序編譯時發生錯誤,關于EL表達式的內容的總結就這么多。
以上內容通過實例給大家詳解介紹了Javaweb El表達式的相關知識,希望對大家有所幫助,同時也非常感謝大家對服務器之家網站的支持!