el表达式跟ognl表达式的区别(转)

Struts
2中的OGNL

EL表达式: 
>>单纯在jsp页面中出现,是在四个作用域中取值,page,request,session,application.
>>如果在struts环境中,它除了有在上面的四个作用域的取值功能外,还能从值栈(valuestack)中取值.
>>特点1:${name},name在值栈中的查找顺序是:先从对象栈中取,取到终止,否则,向map中取。
>>特点2:在对象栈的查找顺序是,先从model中找是否有name这个属性,找到终止,否则,找action中是否有name这个全局变量。
>>特点3:${#name},里面的是不带#号的。
>>特点4:如果放在对象栈中的是一个自定义的对象,那么${property}里面可以直接去该对象的属性值,不用这样${object.property}

本人是一个EL(Expression
Language,以下译为表达式语言)的支持者。因为我对<%
%>写法极为反感,忘记了在那本书上看到的一句话——“使用标志(Tag)的一个目的就是避免在JSP页面中出现过多的<%%>的语句,使页面与后台代码分离。”

OGNL表达式:
1:读取从后台传递的值
%{#name}:表示从值栈的map中取值
%{name}:表示从值栈的对象栈中取值
%{#request.name}:表示从request域中取值

表达式语言主要有以下几大好处:

2:自己构建数据
  a,构建Map<s:iterator var=”map”
value=”#{‘key1′:’value1′,’key2′:’value2’}”/>
  b,构建List<s:iterator var=”list” value=”{‘one’,’two’,’three’}”>

  1. 避免(MyType)
    request.getAttribute()和myBean.getMyProperty()之类的语句,使页面更简洁;

  2. 支持运算符(如+-*/),比普通的标志具有更高的自由度和更强的功能;

  3. 简单明了地表达代码逻辑,使用代码更可读与便于维护。

 

Struts2 ognl中的#、%和$符号用法说明

 

阿超
发表于 10 11月, 2008

1.区别

用法区别:OGNL是通常要结合Struts 2的标志一起使用,如<s:property
value=”#xx” />
struts页面中不能单独使用,el可以单独使用 ${sessionScope.username} 

 

页面取值区别:

 

 名称

servlet

ognl                                                                           el

parameters

request.getParameter("username")

#username                                             ${username}

request

request.getAttribute("userName")

#request.userName                                ${requestScope.username}

session

session.getAttribute("userName")

#session.userName                               ${sessionScope.username}

application

application.getAttribute("userName")

#application.userName                          ${applicationScope.username}

attr

用于按request > session > application顺序访问其属性(attribute)

#attr.userName相当于按顺序在以上三个范围(scope)内读取userName属性,直到找到为

 

 

3 Comments

2.ognl讲解

**OGNL**Struts 2默认的表达式语言。是Object Graphic Navigation
Language(对象图导航语言)的缩写,它是一个开源项目。

 1.#符号的用途一般有三种。  
 1)访问非根对象属性,例如示例中的#session.msg表达式,由于Struts
2中值栈被视为根对象,所以访问其他非根对象时,需要加#前缀。实际上,#相当于ActionContext.getContext();;#session.msg表达式相当于ActionContext.getContext().getSession().
getAttribute(”msg”) 。    
2)用于过滤和投影(projecting)集合,如示例中的persons.{?#this.age>20}。

    3)用来构造Map,例如示例中的#{’foo1′:’bar1′, ’foo2′:’bar2′}。

 

2.%符号 %符号的用途是在标志的属性为字符串类型时,计算OGNL表达式的值。如下面的代码所示:
构造Map

  1. <s:set name=”foobar” value=”#{’foo1′:’bar1′, ‘foo2′:’bar2′}” />  
  2. <p>The value of key “foo1″ is <s:property value=”#foobar[‘foo1’]” /></p>  
  3. <p>不使用%:<s:url value=”#foobar[‘foo1’]” /></p>  
  4. <p>使用%:<s:url value=”%{#foobar[‘foo1’]}” /></p>   

  5. <s:set name=”foobar” value=”#{’foo1′:’bar1′, ‘foo2′:’bar2′}” />  

  6. <p>The value of key “foo1″ is <s:property value=”#foobar[‘foo1’]” /></p>  
  7. <p>不使用%:<s:url value=”#foobar[‘foo1’]” /></p>  
  8. <p>使用%:<s:url value=”%{#foobar[‘foo1’]}” /></p>   

 

3.$符号

$符号主要有两个方面的用途。  
 在国际化资源文件中,引用OGNL表达式,例如国际化资源文件中的代码:reg.agerange=国际化资源信息:年龄必须在${min}同${max}之间。
    在Struts 2框架的配置文件中引用OGNL表达式,例如下面的代码片断所示:

  1. <validators>  
  2.     <field name=”intb”>  
  3.             <field-validator type=”int”>  
  4.             <param name=”min”>10</param>  
  5.             <param name=”max”>100</param>  
  6.             <message>BAction-test校验:数字必须为${min}为${max}之间!</message>  
  7.         </field-validator>  
  8.     </field>  
  9. </validators>  

  10. <validators>  

  11.     <field name=”intb”>  
  12.             <field-validator type=”int”>  
  13.             <param name=”min”>10</param>  
  14.             <param name=”max”>100</param>  
  15.             <message>BAction-test校验:数字必须为${min}为${max}之间!</message>  
  16.         </field-validator>  
  17.     </field>  
    1. </validators>  
  18.  

分类 [
Java,
编程开发
]

#、%和$符号在OGNL表达式中经常出现,而这三种符号也是开发者不容易掌握和理解的部分。在这里笔者简单介绍它们的相应用途。

1.#符号的用途一般有三种。

   1)访问非根对象属性,例如示例中的#session.msg表达式,由于Struts 2中值栈被视为根对象,所以访问其他非根对象时,需要加#前缀。实际上,#相当于ActionContext. getContext();#session.msg表达式相当于ActionContext.getContext().getSession().
getAttribute(”msg”) 。

    2)用于过滤和投影(projecting)集合,如示例中的persons.{?#this.age>20}。

    3)用来构造Map,例如示例中的#{’foo1′:’bar1′, ’foo2′:’bar2′}。

2.%符号

%符号的用途是在标志的属性为字符串类型时,计算OGNL表达式的值。如下面的代码所示:
构造Map
<s:set name=”foobar” value=”#{’foo1′:’bar1′, ‘foo2′:’bar2′}”
/>

<p>The value of key “foo1″ is <s:property
value=”#foobar[‘foo1’]” /></p>

<p>不使用%:<s:url value=”#foobar[‘foo1’]”
/></p>

<p>使用%:<s:url
value=”%{#foobar[‘foo1’]}” /></p>

 3**.$符号**

$符号主要有两个方面的用途。

   在国际化资源文件中,引用OGNL表达式,例如国际化资源文件中的代码:reg.agerange=国际化资源信息:年龄必须在${min}同${max}之间。

    在Struts 2框架的配置文件中引用OGNL表达式,例如下面的代码片断所示:

<validators>

    <field name=”intb”>

            <field-validator type=”int”>

            <param name=”min”>10</param>

            <param name=”max”>100</param>

           
<message>BAction-test校验:数字必须为${min}为${max}之间!</message>

        </field-validator>

    </field>

</validators>

  1.  

Struts
2中的表达式语言

Struts
2支持以下几种表达式语言:

  1. OGNL(Object-Graph
    Navigation Language),可以方便地操作对象属性的开源表达式语言;

  2. JSTL(JSP
    Standard Tag Library),JSP
    2.0集成的标准的表达式语言;

  3. Groovy,基于Java平台的动态语言,它具有时下比较流行的动态语言(如Python、Ruby和Smarttalk等)的一些起特性;

  4. Velocity,严格来说不是表达式语言,它是一种基于Java的模板匹配引擎,具说其性能要比JSP好。

Struts
2默认的表达式语言是OGNL,原因是它相对其它表达式语言具有下面几大优势:

  1. 支持对象方法调用,如xxx.doSomeSpecial();

  2. 支持类静态的方法调用和值访问,表达式的格式为@[类全名(包括包路径)]@[方法名
    |  值名],例如:@java.lang.String@format(‘foo
    %s’, ‘bar’)或@tutorial.MyConstant@APP_NAME;

  3. 支持赋值操作和表达式串联,如price=100,
    discount=0.8, calculatePrice(),这个表达式会返回80;

  4. 访问OGNL上下文(OGNL
    context)和ActionContext;

  5. 操作集合对象。

OGNL的用法

OGNL是通常要结合Struts
2的标志一起使用,如<s:property
value=”xx” />等。大家经常遇到的问题是#、%和$这三个符号的使用。下面我想通过例子讲述这个问题:

首先新建名为Struts2_OGNL的Web工程,配置开发环境。之前很多朋友在使用Struts
2的过程中都遇到乱码问题。当然乱码问题由来已久,而且涉及多方面的知识,所以并非三言两语可以说明白,而且互联网上也已经有很多这方便的文章,大家可以Google一下。不过,如果你在开发的过程,多注意一下,避免乱码问题也不难。乱码多数是由于编码与解码所使用的方式不同造成的,所以我建议大家将编码方式都设为“utf-8”,如<%@ 
page language=”java” contentType=”text/html; charset=utf-8″
pageEncoding=”utf-8″ %>。另外,在配置web.xml时使用ActionContextCleanUp过滤器(Filter),如下面代码所示:

<?xml
version=”1.0″ encoding=”UTF-8″?>
<web-app
id=”WebApp_9″
version=”2.4″
    xmlns=””
    xmlns:xsi=””
    xsi:schemaLocation=”
;

    <display-name>Struts
2 OGNL</display-name>
    
    <filter>
        <filter-name>struts-cleanup</filter-name>
        <filter-class>
            org.apache.struts2.dispatcher.ActionContextCleanUp
        </filter-class>
    </filter>
    
    <filter-mapping>
        <filter-name>struts-cleanup</filter-name>
        <url-pattern>/*</url-pattern>
    </filter-mapping>
    
    <filter>
        <filter-name>struts2</filter-name>
        <filter-class>
            org.apache.struts2.dispatcher.FilterDispatcher
        </filter-class>
    </filter>

    <filter-mapping>
        <filter-name>struts2</filter-name>

相关文章