我遇到了一些代码,它们通过在HttpServletRequest对象上调用getAttribute()来访问存储在struts值栈中的值。我不认为这是可能的,它在哪里记录?
动作类中的代码(它不会将它仅添加到类堆栈中):
private PaginatedChunk searchResults;
public PaginatedChunk getSearchResults() {
return searchResults;
}
public void setSearchResults(PaginatedChunk searchResults) {
this.searchResults = searchResults;
}
这是自定义标记中的代码,用于从请求中提取值(并且它有效!?):
HttpServletRequest request = (HttpServletRequest) pageContext.getRequest();
PaginatedChunk searchResults = (PaginatedChunk) request.getAttribute("searchResults");
有人可以向我解释一下这是如何运作的吗?我认为通过请求无法直接访问Stack值。
我们正在运行struts2 v2.1.8.1
答案 0 :(得分:5)
在这里(http://www.docjar.com/html/api/org/apache/struts2/ServletActionContext.java.html),我们看到“pageContext”的来源:
93 public static PageContext getPageContext() {
94 return (PageContext) ActionContext.getContext().get(PAGE_CONTEXT);
95 }
getContext()。get()返回一个Object,我们知道它是一种PageContext。但实施班是什么?
创建一个简单的操作:
package com.quaternion.action.test;
import com.opensymphony.xwork2.ActionSupport;
public class RequestAccessTest extends ActionSupport{
public String getGreeting(){
return "Hello from Request AccessTest";
}
}
然后在JSP中:
<%@taglib prefix="s" uri="/struts-tags"%>
<%@page contentType="text/html" pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<body>
<h1>Request Access Test</h1>
<%
HttpServletRequest r = (HttpServletRequest) pageContext.getRequest();
String aGreeting = (String) r.getAttribute("greeting");
System.out.println(aGreeting);
System.out.println("R's class is:" + r.getClass().getCanonicalName());
%>
</body>
</html>
在我的控制台上,我看到了打印:
INFO: Hello from Request AccessTest
INFO: R's class is:org.apache.struts2.dispatcher.StrutsRequestWrapper
所以我们真的在处理一个StrutsRequestWrapper(现在我们知道我们实际处理它的事情很简单)......
查看上面的链接我们看到getAttribute确实被覆盖了。
从第65行开始,我们看到它试图从请求中获取值,然后如果失败则继续将其从值堆栈中取出。
这在哪里记录?我想这里有记录,截至目前;)