Interceptor中ValueStack设值的问题

Interceptor,invocation.invoke();之前设值是有效的,之后却失效了,代码如下:
[code="java"]
@Override
public String intercept(ActionInvocation invocation) throws Exception {
ActionContext context = ActionContext.getContext();
ValueStack vs = context.getValueStack();
vs.set("dddd", "ddddddddddd");

    String result = invocation.invoke();

    System.out.println("$$$$$$$$$$"+vs.findString("dddd"));
    vs.set("dddd", "ffffffffffff");
    System.out.println("$$$$$$$$$$"+vs.findString("dddd"));

}

[/code]

console输出结果是对的:
$$$$$$$$$$ddddddddddd
$$$$$$$$$$ffffffffffff

jsp显示是错的:
--> ddddddddddd
谁见过这个问题?
(Interceptor是定义在最下面的,最接近action了)

invocation.invoke()后,在vs.set("dddd", "ffffffffffff")之前action就已经执行了
修改如下试试

ActionContext context = ActionContext.getContext();

ValueStack vs = context.getValueStack();

vs.set("dddd", "ddddddddddd");

System.out.println("$$$$$$$$$$"+vs.findString("dddd"));

vs.set("dddd", "ffffffffffff");

System.out.println("$$$$$$$$$$"+vs.findString("dddd"));

String result = invocation.invoke();