zoukankan      html  css  js  c++  java
  • Struts2入门(五)——OGNL和标签库

    一、前言

    OGNL和标签库的作用,粗暴一点说,就是减少在JSP页面中出现java代码,利于维护。

    1.1、OGNL

    1.1.1、什么是OGNL?

    OGNL(Object-Graph Navigation Language):对象图形导航语言,是一种功能强大的表达式语言,通过简单的语法,就能够任意存取对象的属性或者调用对象的方法,能够遍历整个对象的结构图,实现对象属性的类型转换功能。

    1.1.2、OGNL的基本知识

    1.OGNL表达式的计算是围绕OGNL上下文进行的

    OGNL上下文实际上就是一个Map对象,由ognl.OgnlContext类表示。它里面可以存放很多个JavaBean对象。

    它有一个上下文根对象。上下文中的根对象可以直接使用名来访问或直接使用它的属性名访问它的属性值。否则要加前缀“#key”。

    2.Struts2的标签库都是使用OGNL表达式来访问ActionContext中的对象数据的。如:<s:propertyvalue="xxx"/>。

    3.Struts2将ActionContext设置为OGNL上下文,并将值栈作为OGNL的根对象放置到ActionContext中。

    4.值栈(ValueStack) :

    可以在值栈中放入、删除、查询对象。访问值栈中的对象不用“#”。

    Struts2总是把当前Action实例放置在栈顶。所以在OGNL中引用Action中的属性也可以省略“#”。

    5.调用ActionContext的put(key,value)放入的数据,需要使用#访问。

    OGNL上下文存储图

    1.1.3、OGNL中有三个重要的符号:#、%、$

    "#"符号的用途:

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

    2、用于过滤和投影(projecting)集合,如persons.{?#this.age>25}.{age},persons.{?#this.name=='pla1'}.{age}[0]。(persons:表示存放在内含对象的值。其中问号?是把所有满足条件的元素都取出来。)

    3、构造Map和List

    "%"符号的用途:

    "%"符号的用途是在标签的属性值被理解为字符串类型时,告诉执行环境%{}里的是OGNL表达式。(等下例子有介绍)

    "$"符号的用途:

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

    2、在struts.xml中引用OGNL表达式,如:

    下面通过例子来进行说明:

    新建jsp页面:

    <%@page import="java.util.LinkedList"%>
    <%@page import="java.util.List"%>
    <%@page import="com.Ogml.Persons"%>
    <%@page import="org.apache.struts2.ServletActionContext"%>
    <%@page import="com.opensymphony.xwork2.ActionContext"%>
    <%@ page language="java" contentType="text/html; charset=UTF-8"
        pageEncoding="UTF-8"%>
    <%@ taglib uri="/struts-tags" prefix="s"%>    
    <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
    <html>
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
    <title>学习OGNL</title>
    </head>
    <body>
        <%
            ActionContext ctx = ActionContext.getContext();
            ctx.getApplication().put("msg", "application消息");
            ctx.getSession().put("msg","session消息");
            ctx.getParameters().put("msg", "parameters消息");
            
            HttpServletRequest re = ServletActionContext.getRequest();
            re.setAttribute("msg", "request消息");
        %>
        
        <!-- 使用OGNL访问属性值 -->
        <!--OGNL中的#号可以取出堆栈上下文中存放的对象  -->
        <p>parameters:<s:property value="#parameters.msg"/></p>
        <p>Application:<s:property value="#application.msg"/></p>
        <p>session:<s:property value="#session.msg"/></p>
        <p>request:<s:property value="#request.msg"/></p>
        <!-- 使用attr:表示它会自动从request-session-applicatioin中寻找,如果找到则返回 -->
        <p>attr:<s:property value="#attr.msg"/></p>
        
        <!--使用OGNL处理集合List,Map-->
        <p>使用List集合:<s:select name="color" list="{'red','yellow','green'}" /></p>
        <p>使用Map集合:
        <s:set var="colors" value="#{'color1':'yellow' }"/>
        <s:property value="#colors['color1']"/></p>
        
        <!-- 不使用%输出结果是:#colors['color1'] -->
        <p>不使用%:<s:url value="#colors['color1']"/></p>
        <!-- “%”符号的用途是在标签的属性值被理解为字符串类型时,告诉执行环境%{}里的是OGNL表达式。  -->
        <p>使用%:<s:url value="%{#colors['color1']}"/></p>
        
        <!-- 过滤和投影(projecting) -->
        <%    
            Persons p1 = new Persons();
            p1.setUname("lisi");
            p1.setAge(36);

         application.setAttribute(
    "p", p1); %> <!-- 问号?是把所有满足条件的元素都取出来。 --> <!-- {?#this.age>20}表示的是:获取当前对象的属性,这是一个表达式,如果是true的话,则后面查询的值会输出。false则不会 --> <p>使用?#:<s:property value="#application.p.{?#this.age>20}.{uname}"/></p> <!-- 输出的是[lisi],有中括号的表示这是一个列表 --> <!-- 上箭头^是开始的意思,即取符合条件的数据索引中第一条数据 --> <p>使用^#:<s:property value="#application.p.{^#this.age>20}.{age}[0]"/></p> <!-- 输出的是36,没有中括号,表示这个一个字符串 --> <!-- 前提必须在strtus.xml中添加 <constant name="struts.ognl.allowStaticMethodAccess" value="true"></constant> --> <!-- 使用@访问静态方法 --> <s:property value="@com.Ogml.Persons@sayhello()"/> <!-- 使用@访问静态属性 --> <s:property value="@com.Ogml.Persons@sex"/><br/> </body> </html>

    例子中有使用到^、@符号:

    ^符号表示的是去符合条件的第一条数据

    @符号表示调用类的静态方法或者属性

    另外还有美元符号$是结束的意思,即取符合条件的数据索引中最后一条数据,如:

    #application.p.{$#this.age>=60}.{uname}输出的是[zhangsan]。

    注意:如果使用OGNL要调用静态方法(但是据说Struts2最新版本不允许使用静态方法了,好像说是安全问题。有兴趣可以自己试下)或者静态属性的时候,struts.xml一定要配置:

    <constant name="struts.ognl.allowStaticMethodAccess" value="true"></constant>,该语句,不然无法调用。如下:

    persons类代码如下:

    package com.Ogml;
    
    import java.io.StringWriter;
    
    public class Persons {
        public static String sex = "男";
        private String uname;
        private int age;
        public String getUname() {
            return uname;
        }
        public void setUname(String uname) {
            this.uname = uname;
        }
        public int getAge() {
            return age;
        }
        public void setAge(int age) {
            this.age = age;
        }
        
        public static void sayhello(){
            System.out.println("hello");
        }
    }
    Persons

    仅作为笔记记录。

    1.2、标签库

     笔者对于标签库这些,真的不太感兴趣。但是没办法,还是的学着,发下牢骚。

    1.2.1、标签库的好处

    在Struts2中,它提供了大量的标签来生成页面效果,简单说来就是使用标签库中为我们提供的标签来达到我们想过的页面效果。而且标签库的使用非常简单,struts2把所有的标签都定义在URI为"/struts-tags"的命名空间下,我们只需要在页面中引入:<%@ taglib uri="/struts-tags" prefix="s"%>,就可以使用该标签库。

    1.2.2、标签库的简单分类

    UI标签:主要用于生产HTML元素的标签

    非UI标签:主要用户数据访问,逻辑控制标签等

    Ajax标签:用户Ajax支持的标签

    对于UI标签,则可以分为两类:

    1、表单标签:主要生成HTML页面的form元素以及普通标签元素

    2、非表单标签:主要用于生成页面上的数据,tag页等标签

    非UI标签,也可以分为两类:

    1、流程控制标签:主要用于实现分支,循环等流程控制的标签

    2、数据访问标签:主要包含输出valueStack中的值,完成国际化等功能的标签

    这样就清晰多了。

  • 相关阅读:
    模式识别之检索---Bag of visual word(词袋模型)
    模式识别之knn---KNN(k-nearest neighbor algorithm)--从原理到实现
    目标跟踪之meanshift---meanshift2
    图像处理之增强---图像模糊检测
    模式识别之非参数估计---非参估计中的核函数
    haproxy文章
    nginx 有关防盗链的设置
    haproxy 关闭ssl3
    navicat 在写存储过程的时候总是说语法错误
    开源的报表系统easyreport的部署
  • 原文地址:https://www.cnblogs.com/IT-1994/p/6012223.html
Copyright © 2011-2022 走看看