Struts2中获取Request,Response的几种方法

简介:     在Struts2中的没有像Struts1那样必须要在Action类中写个execute()方法,只需要是个返回字符串的方法即可(有时候也不需要返回值),在struts2中经将原有的servlet中request参数和response参数封装在拦截器中,可是有时候编程的时候仍然需要用到这两个参数。

    在Struts2中的没有像Struts1那样必须要在Action类中写个execute()方法,只需要是个返回字符串的方法

即可(有时候也不需要返回值),在struts2中经将原有的servlet中request参数和response参数封装在拦截器

中,可是有时候编程的时候仍然需要用到这两个参数。以下是获得该参数的几种方法:


    方法一:使用Struts2 Aware拦截器

这种方法需要Action类实现相应的拦截器接口。如我们要获得HttpServletResponse对象,需要现

org.apache.struts2.interceptor.ServletResponseAware接口,代码如下:

  1. public class MyAction extends ActionSupport implements ServletResponseAware  
  2. {  
  3.     private javax.servlet.http.HttpServletResponse response;  
  4.     // 获得HttpServletResponse对象  
  5.     @Override  
  6.     public void setServletResponse(HttpServletResponse response)  
  7.     {  
  8.         this.response = response;  
  9.     }      
  10.     public String execute() throws Exception  
  11.     {      
  12.         response.getWriter().write("实现ServletResponseAware接口");  
  13.     }  
  14. }  

在上面的代码中,MyAction实现了一个ServletResponseAware接口,并且实现了setServletResponse方法。

如果一个动作类实现了ServletResponseAware接口,Struts2在调用execute方法之前,就会先调用setServletResponse方法,并将response参数传入这个方法。如果想获得HttpServletRequest、HttpSession和Cookie等对象,动作类可以分别实现ServletRequestAware、SessionAware和CookiesAware等接口。这些接口都在org.apache.struts2.interceptor包中。

如果要获得请求参数,动作类可以实现org.apache.struts2.interceptor. ParameterAware接口,但如果只想断某个参数是否存在,也可以实现com.opensymphony.xwork2.interceptor. ParameterNameAware接口。这个接口有一个acceptableParameterName方法,当Struts2获得一个请求参数时,就会调用一次。读者可以在这个方法中将所有的请求参数记录下来,以便以后使用。这个方法的定义如下:

boolean acceptableParameterName(String parameterName);


    方法二、使用RequestAware拦截器

这种方法和第1种方法类似。动作类需要实现一个org.apache.struts2.interceptor.RequestAware接口。所不同的

是RequestAware将获得一个com.opensymphony.xwork2.util.OgnlValueStack对象,这个对象可以获得response、

request及其他的一些信息。代码如下所示:

public class FirstAction extends ActionSupport implements RequestAware {  
    private Map request;  
    private HttpServletResponse response;  
  
    public void setRequest(Map request) {  
        this.request = request;  
    }  
  
    public String execute() throws Exception {  
        java.util.Set<String> keys = request.keySet();  
        // 枚举所有的key值。实际上只有一个key:struts.valueStack  
        for (String key : keys)  
            System.out.println(key);  
        // 获得OgnlValueStack 对象  
        OgnlValueStack stack = (OgnlValueStack) request  
                .get("struts.valueStack");  
        // 获得HttpServletResponse对象  
        response = (HttpServletResponse) stack.getContext().get(  
                StrutsStatics.HTTP_RESPONSE);  
        response.getWriter().write("实现RequestAware 接口");  
    }  
}

我们也可以使用StrutsStatics.HTTP_REQUEST、StrutsStatics.PAGE_CONTEXT来获得HttpServletRequest和

PageContext对象。这种方法有些麻烦,一般很少用,读者可以作为一个参考。


    方法三、使用ActionContext类

这种方法比较简单,我们可以通过org.apache.struts2.ActionContext类的get方法获得相应的对象。代码如下:

ActionContext ctx = ActionContext.getContext();       
HttpServletRequest request =(HttpServletRequest)ctx.get(ServletActionContext.HTTP_REQUEST);    
HttpServletResponse response = (HttpServletResponse)  
ActionContext.getContext().get(org.apache.struts2.StrutsStatics.HTTP_RESPONSE);  

    

    方法四、使用ServletActionContext类

Struts2为我们提供了一种最简单的方法获得HttpServletResponse及其他对象。这就是

org.apache.struts2.ServletActionContext类。我们可以直接使用ServletActionContext类的getRequest、

getResponse方法来获得HttpServletRequest、HttpServletResponse对象。代码如下:

HttpServletRequest request = ServletActionContext.getRequest();  
HttpServletResponse response = ServletActionContext.getResponse(); 

从这四种方法来看,最后一种是最简单的,读者可以根据自己的需要和要求来选择使用哪一种方法来获得这些对象。


相关文章
|
前端开发 Java 程序员
记录:java.net.SocketTimeoutException: connect timed out...【亲测有效】
记录:java.net.SocketTimeoutException: connect timed out...【亲测有效】
2867 0
|
JSON 监控 Java
Java中如何解决JsonProcessingException异常?
Java中如何解决JsonProcessingException异常?
|
NoSQL Linux 网络安全
解决Caused by: java.net.SocketTimeoutException: connect timed out Exception in thread “main“ redis.cli
解决Caused by: java.net.SocketTimeoutException: connect timed out Exception in thread “main“ redis.cli
605 0
|
缓存 中间件 API
GoFrame第二天
GoFrame第二天
598 0
GoFrame第二天
|
7天前
|
缓存 测试技术 API
Qwen 3.7 Plus 与 Max 实测:性价比与多模态能力差异解析(2026)
2026 年 6 月 1 日,阿里悄无声息地发布了 Qwen 3.7 Plus,距 Qwen 3.7 Max 上线刚好 11 天。同样的 1M 上下文,同样的 35 小时自治上限。但价格才是头条:Plus 是 0.40/M输入,Max是 2.50/M——便宜约 6 倍——并且还能看图、看视频。Vision Arena 上 Plus 已经排到 #16。所以这周真正值得讨论的问题不是”要不要为视觉能力买单”,而是”Max 凭什么用 6 倍价格换来 2 个百分点的 benchmark 领先”。
|
8天前
|
JavaScript 定位技术 API
CodeGraph 爆火:编程 Agent 需要的不是更多上下文,而是一张提前画好的代码地图
CodeGraph 是一款爆火的本地代码智能工具,通过 tree-sitter 解析 AST 构建结构化知识图谱(存于 SQLite),为编程 Agent 提前生成“代码地图”。它显著降低 Agent 在中大型项目中的探索成本——实测工具调用减少71%、Token 降57%、速度提升46%,支持19+语言及主流框架路由识别,完全离线、无需 API Key。
760 8
CodeGraph 爆火:编程 Agent 需要的不是更多上下文,而是一张提前画好的代码地图
|
2天前
|
缓存 前端开发 API
GLM 5.2 自托管部署实战指南:硬件配置选择、vLLM 推理优化与运营成本分析
智谱这次发布 GLM 5.2 不只是开了个 API。MIT 许可的权重本周也上了 HuggingFace,这意味着头一回有一款前沿级别、1M 上下文的代码模型,你能真正拉下来、审计、跑在自己机器上。代价是机器本身:753B 参数塞不进你桌下的笔记本。
|
8天前
|
人工智能 运维 JavaScript
阿里云Qoder CN(原通义灵码)全解析 产品形态、版本划分与技术适配说明
在AI辅助开发与智能办公工具持续普及的当下,阿里云旗下原通义灵码正式更名为Qoder CN,同时延伸出QoderWork CN、Qoder CN CLI、Qoder CN Mobile等多款配套产品,形成覆盖代码开发、日常办公、终端交互、移动端使用的完整工具矩阵。Qoder CN核心定位为AI智能编码助手,深度适配主流代码编辑器、集成开发环境以及终端场景;QoderWork CN则偏向桌面端综合办公辅助,二者面向不同使用场景,划分了多个版本档位,搭配差异化资源配额、功能权限与计费规则,同时兼容多款主流大模型。
746 7
|
8天前
|
存储 安全 Java
AgentScope Java 2.0:打造分布式、企业级智能体底座
AgentScope 2.0 面向分布式部署、稳定运行、权限安全等企业级需求全面升级,打造支持多租户隔离与长期稳定运行的企业级智能体底座。

热门文章

最新文章