zoukankan      html  css  js  c++  java
  • Struts2取值

    1.标签取值方式一

        通过<s:property value="" />取值

        当Action的valueStack中有该属性的值时,只需直接使用该属性的名字即可;

        当Action的valueStack中没有该属性的值时,比如在session,application范围中的属性值时,需要加#或者#attr.;

        例子:

        假设某Action中有person成员变量,在application中存在company属性

        那么我们可以通过以下方法取值:

        <s:property value="person.name" />

        <s:property value="#person.name" />

        <s:property value="company.name" /> //无法取到,因为company不在action的valueStack中

        <s:property value="#company.name" />

    2.标签取值方式二

    在任意的<s:/>标签内使用%{}来取值

    当Action的valueStack中有该属性的值时,只需直接使用该属性的名字即可;

    当Action的valueStack中没有该属性的值时,比如在session,application范围中的属性值时,需要加#或者#attr.;

    例子:

    假设某Action中有person成员变量,在application中存在company属性

    <s:textfield name="person.name" value="person.name" /> //错误,value会直接显示person.name字样

    <s:textfield name="person.name" value="%{person.name}" />

    <s:textfield name="person.company.name" value="%{#company.name}" />

    <s:textfield name="person.company.name" value="%{#attr.company.name}" />

    3.获取JSP页面的request,session,application中的属性

       在页面中可以这样获取:

    <td>${applicateionScope.counter}</td>

    <td>${sessionScope.counter}</td>

    <td>${requestScope.counter}</td>

    或者直接这样用:${属性} ${userBean.username}。userBean可以是request或session中的对象。

    struts2中的Action代码中的内容为:

    ActionContext ctx = ActionContext.getContext();

    ctx.getApplication.put("counter",new Integer(5));

    ctx.getSession.put("counter",new Integer(5));

    ctx.put("counter",new Integer(5));

    ctx.put就是直接设置request的值。

    也可以使用以下方式获得request:

    HttpServletRequest r = ServletActionContext.getRequest();

    HttpServletResponse resp = ServletActionContext.getResponse();

    struts2还提供了以下接口:

    ServletContextAware:Action实现该接口,可以直接访问ServletContext。

    ServletRequestAware:Action实现该接口,可以直接访问HttpServletRequest。

    ServletResponseAware:Action实现该接口,可以直接访问HttpServletResponse。

  • 相关阅读:
    【SQL注入技巧拓展】————11、PostgreSQL渗透测试指南
    【SQL注入技巧拓展】————10、postgresql数据库利用方式
    【XXE技巧拓展】————3、XML实体注入漏洞攻与防
    【XXE技巧拓展】————2、未知攻焉知防之XXE漏洞攻防
    【XXE技巧拓展】————1、浅谈XXE漏洞攻击与防御
    S2-032 远程代码执行漏洞检测与利用
    S2-029 远程代码执行漏洞检测与利用
    Rendering Paths
    IOS: 模型面数控制
    IOS: 账号,证书 好文整理
  • 原文地址:https://www.cnblogs.com/564085446java/p/3611444.html
Copyright © 2011-2022 走看看