关于OGNL表达式

来源:互联网 发布:ubuntu fn无法使用 编辑:程序博客网 时间:2024/04/29 15:28


struts2框架使用OGNL作为默认的表达式语言。
OGNL是从ActionContext中获取数据的。
小技巧:在JSP页面使用<s:debug/>查看上下文中的对象
 <s:debug></s:debug>

相对于EL表达式,它提供了平时我们需要的一些功能,如:
 1.支持对象方法调用,如xxx.sayHello();
 2.支持类静态方法调用和值访问,表达式的格式为@[类全名(包括包路径)]@[方法名|值名],例如:@java.lang.String@format('foo %s', 'bar')
 3.操作集合对象

Ognl有一个上下文(Context)概念,说白了上下文就是一个MAP结构,它实现了java.utils.Map接口,在struts2中上下文(Context)的实现为ActionContext,下面是上下文的结构示意图:

struts2中的OGNL Context实现者为ActionContext,它的结构示意图为:
  
  value stack(root)
   List:动作类放在此处。取存放在ValueStack中的root的对象的属性,直接写即可。
   访问以下内容中的对象要使用#+(范围)session
  session:HttpSession中的那个Map

  application:ServletContext中的那个map
context map
  request:ServletRequest中的那个Map

  parameters:请求参数的那个map(如同EL表达式的paramValues内置对象)

  attr(searches page, request, session, then application scopes):相当于使用PageContext的findAttribute方法。
  
★★★★★当struts接受一个请求时,会迅速创建ActionContext,ValueStack,Action。然后把action存放进ValueStack,所以action的实例变量可以被OGNL访问。

访问上下文(Context)中的对象需要使用#符号标注命名空间,如#application、#session

另外OGNL会设定一个根对象(root对象),在struts2中根对象就是ValueStack(值栈)。
如果要访问根对象(即ValueStack)中对象的属性,则可以省略#命名空间,直接访问该对象的属性即可。

在Struts2中,根对象ValueStack的实现类为OgnlValueStack,该对象不是我们想象的只存放单个值,而是存放一组对象。
在OgnlValueStack类里有一个List类型的root变量,就是使用它存放一组对象。

Context-----OnglValueStack  root变量[action,OgnlUtil,…]

在root变量中处于第一位的对象叫栈顶对象。
通常我们在OGNL表达式里直接写上属性的名称即可访问root变量里对象的属性,搜索顺序是从栈顶对象开始寻找,
如果栈顶对象不存在该属性,就会从第二个对象寻找,如果没有找到就从第三个对象寻找,依次往下访问,直到找到为止。

注意:Struts2中,OGNL表达式需要配合Struts标签才可以使用。如:<s:property value=“name”/>


由于ValueStack(值栈)是Struts2中OGNL的根对象,如果用户需要访问值栈中的对象,
在JSP页面可以直接通过下面的EL表达式访问ValueStack(值栈)中对象的属性:
${foo}//获得值栈中某个对象的foo属性。

如果访问其他Context中的对象,由于他们不是根对象,所以在访问时,需要添加#前缀
application对象:用于访问ServletContext,例如#application.userName或者#application[‘userName’],相当于调用ServletContext的getAttribute(“username”)。

session对象:用来访问HttpSession,例如#session.userName或者#session[‘userName’],相当于调用session.getAttribute(“userName”)。

request对象:用来访问HttpServletRequest属性(attribute)的Map,例如#request.userName或者#request[‘userName’],相当于调用request.getAttribute(“userName”)。

parameters对象:用与访问HTTP的请求参数,例如#parameters.userName或者#parameters[‘userName’],相当于调用request.getParameter(“username”)。

attr对象:用于按page→request→session→application顺序访问其属性。



list
 创建list  <s:set var="list1" value='{"a","b","c"}'></s:set>默认放到了ActionContext上下文中,scope="action"
   <s:set var="list2" value="{'aa','bb','cc'}" scope="session" />
   
 拿list1第二个元素的值 <s:property value="#list1{1}"/>// 拿取list1中的b值
 拿list2所有元素的值 <s:iterator value="#session.list2" var="l">
     <s:property value="#l">
    </s:iterator>
 
map
 创建map  <s:set var="map1" value="#{'a':'valuea', 'b':'valueb'}"/>
 拿值  <s:iterator value="#map1" var="me">
    <s:property value="#me.key"/>=<s:property value="#me.value"/>
   </s:iterator><!-- 作用如同forEach -->


0 0
原创粉丝点击