例: ${sessionScope.user.sex} 所有EL都是以 ${ 为起始、以} 为结尾的。 上述EL范例的意思是:从Session取得用户的性别。
如果使用之前JSP代码的写法如下: <% User user = (User)session.getAttribute(”user”); String sex = user.getSex( ); %>
两者相比较之下,可以发现EL的语法比传统JSP代码更为方便、简洁。 EL提供 . 和 [ ] 两种运算符来存取数据,[ ]可以访问集合或者是数组的元素、Bean的属性。 下列两者所代表的意思是一样的,但是需要保证要取得对象的那个的属性有相应的setXxx()和getXxx()方法才行。
例: ${sessionScope.user.sex} 等于 ${sessionScope.user["sex"]} . 和 [ ] 也可以同时混合使用,如下: ${sessionScope.shoppingCart[0].price} 返回结果为shoppingCart中第一项物品的价格。 在EL中,字符串既可以使用”abc”,可以使用’abc’。
==================================================================== EL运算符 EL的算术运算符和Java中的运算符的大致相同,优先级也相同。 注意:’+’ 运算符不会连接字符串了,他只用于加法运算。 EL关系运算符有以下六个运算符 关系运算符 说 明 范 例 结果 = = 或 eq | 等于 |${ 5 = = 5 } 或 ${ 5 eq 5 } | true != 或 ne | 不等于 |${ 5 != 5 } 或 ${ 5 ne 5 } | false < 或 lt | 小于 |${ 3 < 5 }或 ${ 3 lt 5 } | true > 或 gt | 大于 |${ 3 > 5 }或 ${ 3 gt 5 } | false <= 或 le | 小于等于 |${ 3 <= 5 }或 ${ 3 le 5 } | true >= 或 ge | 大于等于 |${ 3 >= 5 }或 ${ 3 ge 5 } | false empty运算符 Empty运算符主要用来判断值是否为null或空的,例如: ${ empty param.name } 接下来说明Empty运算符的规则: {empty} A 如果A为null时,返回true 如果A不存在时,返回true 如果A为空字符串时,返回true 如果A为空数组时,返回true 如果A为空的Map时,返回true 如果A为空的Collection时,返回true 否则,返回false 注意: 在使用EL关系运算符时,不能够写成: ${param.password1} = = ${param.password2} 或者 ${ ${param.password1 } = = ${ param.password2 } } 而应写成 ${ param.password1 = = param.password2 } 使用EL从表单中取得数据 与输入有关的隐含对象有两个:param和paramValues,它们是EL中比较特别的隐含对象。 一般而言,我们在取得用户的请求参数时,可以利用下列方法: request.getParameter(String name) request.getParameterValues(String name) 在EL中则可以使用param和paramValues两者来取得数据。 ${param.name} ${paramValues.name}可以取得所有同名参数的值 ${paramValues.hobbies[0]}可以通过指定下标来访问特定的参数的值 这里param的功能和request.getParameter(String name)相同, 而paramValues和request.getParameterValues(String name)相同。 如果用户填了一个form,form名称有为username的文本框,则我们就可以使 用${param.username}来取得用户填入文本框的值。
===================================================================== EL函数 EL中使用函数要写一个要使用到方法的类,然后在配置xxx.tld文件,然后在JSP中使用时和JSP的自定义标签相似。 xxx.tld中的配置 <function> <name>reverse</name><!–函数名–> <function-class>jsp2.examples.el.Functions</function-class><!–函数所在的类–> <function-signature>java.lang.String reverse( java.lang.String )</function-signature> <!–函数原型,也就是函数的返回值类型,函数名,参数表,注意一定要写类型的全名–> </function>
使用EL函数的写法 ${sn:upper(’abc’)} 注意:在定义EL函数时,都必须为公开静态(public static) =============================================================== EL的隐含对象 EL也可以使用内置对象中设置的属性,需要使用特定的EL内置对象 属性范围 | 在EL中的对象 Page | pageScope Request | requestScope Session | sessionScope Application | applicationScope =============================================================== EL中使用内置对象的属性 ${requestScope.user} 等价于 <%request.getAttribute(”user”)%> 如果不写出特定的范围 ,那就会在不同的范围间进行搜索了 例:{user}(user是在request范围 request.setAttribute(”user”,user)) 也就等于 ${requestScope.user} <%request.getAttribute(”user”)%> =============================================================== EL的隐含对象 对象 类 型 说 明 PageContext | javax.servlet.ServletContext |表示此JSP的PageContext ———————————————————————————– PageScope | java.util.Map |取得Page范围的属性名称所对应的值 ————————————————————————————- RequestScope | java.util.Map |取得Request范围的属性名称所对应的值 ————————————————————————————- sessionScope | java.util.Map |取得Session范围的属性名称所对应的值 ————————————————————————————- applicationScope | java.util.Map |取得Application范围的属称所对应的值 ————————————————————————————- param | java.util.Map |如同ServletRequest.getParameter(String name)返回String类型的值 —————————————————————————————- paramValues | java.util.Map |如同ServletRequest.getParameterValues | (String name)。返回String []类型的值 —————————————————————————————– header | java.util.Map |如同ServletRequest.getHeader(String name) 返回String类型的值 —————————————————————————————— headerValues | java.util.Map |如同ServletRequest.getHeaders(String name) 。返回String []类型的值 —————————————————————————————— cookie | java.util.Map |如同HttpServletRequest.getCookies( ) —————————————————————————————— initParam | java.util.Map |如同ServletContext.getInitParameter(String name)。返回String类型的值 ——————————————————————————————-
=============================================================== cookie对象 所谓的cookie是一个小小的文本文件,它是以key、value的方式将Session Tracking的内容记录在这个文本文件内, 这个文本文件通常存在于浏览器的暂存区内。JSTL并没有提供设定cookie的动作, 因为这个动作通常都是后端开发者必须去做的事情,而不是交给前端的开发者。如果我们在cookie中设定一个名 称为userCountry的值,那么可以使用${cookie.userCountry}来取得它。 header和headerValues(请求报头对象) header储存用户浏览器和服务端用来沟通的数据,当用户要求服务端的网页时,会送出一个记载要求信息的标头文件, 例如:用户浏览器的版本、用户计算机所设定的区域等其他相关数据。如果要取得用户浏览器的版本, 即${header["User-Agent"]}。另外在很少机会下,有可能同一标头名称拥有不同的值,此时必须改为使用headerValues来取得这些值。 注意:因为User-Agent中包含“-”这个特殊字符,所以必须使用“[]”,而不能写成${header.User-Agent}。 =============================================================== initParam 就像其他属性一样,我们可以自行设定web应用的环境参数(Context),当我们想取得这些参数时, 可以使用initParam隐含对象去取得它,例如:当我们在web.xml中设定如下: <?xml version=”1.0″ encoding=”ISO-8859-1″?> <web-app xmlns=”http://java.sun.com/xml/ns/j2ee” xmlns:xsi=”http://www.w3.org/2001/XMLSchema-instance” xsi:schemaLocation=”http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd” version=”2.4″> <context-param> <param-name>userid</param-name> <param-value>mike</param-value> </context-param> </web-app> 那么我们就可以直接使用 ${initParam.userid}来取得名称为userid,其值为mike的参数。 下面是之前的做法:String userid = (String)application.getInitParameter(”userid”); =============================================================== pageContext对象 我们可以使用 ${pageContext}来取得其他有关用户要求或页面的详细信息。下面列出了几个比较常用的部分。 Expression 说 明 ${pageContext.request} |取得请求对象 ${pageContext.session} |取得session对象 ${pageContext.request.queryString} |取得请求的参数字符串 ${pageContext.request.requestURL} |取得请求的URL,但不包括请求之参数字符串 ${pageContext.request.contextPath} |服务的web application的名称 ${pageContext.request.method} |取得HTTP的方法(GET、POST) ${pageContext.request.protocol} |取得使用的协议(HTTP/1.1、HTTP/1.0) ${pageContext.request.remoteUser} |取得用户名称 ${pageContext.request.remoteAddr } |取得用户的IP地址 ${pageContext.session.new} |判断session是否为新的,所谓新的session,表示刚由server产生而client尚未使用 ${pageContext.session.id} |取得session的ID ${pageContext.servletContext.serverInfo}|取得主机端的服务信息
|