Struts2获取request、session、application的三种方法

2024-06-10 00:32

本文主要是介绍Struts2获取request、session、application的三种方法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1、使用ActionContext访问Servlet API

      Struts2提供了一个ActionContext类,该类被称为Action上下文或者Action环境,Action可以通过该类来访问最常用的Servlet API。

①、getContext():静态方法,获取当前的ActionContext对象。

②、getSession():返回一个Map对象,该对象模拟了session作用域。

③、getApplication:返回一个Map对象,该对象模拟了Application作用域。

④、get(String key):对该方法传入“request”参数,即可返回一个Object对象,该对象模拟了request作用域。

⑤、getParameters():返回一个Map对象,该对象中保存了浏览器上传的参数。

特点:作用域都是由Action自己获取的,获取对象和使用对象的代码放在一个类中。

public class UserAction extends ActionSupport {private User user;public User getUser() {return user;}public void setUser(User user) {this.user = user;}public String Login(){HttpServletRequest request = (HttpServletRequest) ActionContext.getContext().get("request");request.setAttribute("username", user.getUserName());
		//也可以转Map哦
		//Map<String,Object> request2 = 
		//	    (Map<String, Object>) ActionContext.getContext().get("request");
	      //request2.put("username", user.getUserName());
		return "success";}
}

2、以IoC的方式访问Servlet API

      Action类中只保留使用这些对象的代码,而获取对象的代码由Struts2来实现。

public class UserAction extends ActionSupport implements RequestAware,SessionAware,ApplicationAware {private Map<String, Object> request;private Map<String, Object> session;private Map<String, Object> application;public void setApplication(Map application) {this.application = application;}public void setSession(Map session) {this.session = session;		}public void setRequest(Map request) {this.request = request;		}public String Login(){//转换成HttpServletRequest,根据需要来HttpServletRequest req=(HttpServletRequest)request;String name = req.getParameter("username");req.setAttribute("username", "张三");return "success";}}
        在上面代码中,Action实现了 RequestAware,SessionAware,ApplicationAware接口,这样Struts2就可以为Action注入request、session、application对象了。

以session为例,Struts2取得session对象,当UserAction被创建时,Struts2会判断UserAction是否实现了SessionAware接口,若实现,就会调用UserAction的setSession()

方法,并把session作为参数传入该方法。该方法的"this.session = session;"代码会把session保存为一个成员变量,这样就实现了session对象注入。


3、以耦合方式访问Servlet API

      即ServletActionContext类,这个类继承了ActionContext类,它提供了直接与Servlet相关对象访问的功能,它可以取得的对象有:
(1)javax.servlet.http.HttpServletRequest : HTTPservlet请求对象
(2)javax.servlet.http.HttpServletResponse : HTTPservlet相应对象
(3)javax.servlet.ServletContext : Servlet上下文信息
(4)javax.servlet.jsp.PageContext : Http页面上下文

ServletActionContext源码:

package org.apache.struts2;
import com.opensymphony.xwork2.ActionContext;
import com.opensymphony.xwork2.util.ValueStack;
import org.apache.struts2.dispatcher.mapper.ActionMapping;
import javax.servlet.ServletContext;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.jsp.PageContext;
import java.util.Map;/*** Web-specific context information for actions. This class subclasses <tt>ActionContext</tt> which* provides access to things like the action name, value stack, etc. This class adds access to* web objects like servlet parameters, request attributes and things like the HTTP session.*/
public class ServletActionContext extends ActionContext implements StrutsStatics {private static final long serialVersionUID = -666854718275106687L;public static final String STRUTS_VALUESTACK_KEY = "struts.valueStack";public static final String ACTION_MAPPING = "struts.actionMapping";@SuppressWarnings("unused")private ServletActionContext(Map context) {super(context);}/*** Gets the current action context** @param req The request* @return The current action context*/public static ActionContext getActionContext(HttpServletRequest req) {ValueStack vs = getValueStack(req);if (vs != null) {return new ActionContext(vs.getContext());} else {return null;}}/*** Gets the current value stack for this request** @param req The request* @return The value stack*/public static ValueStack getValueStack(HttpServletRequest req) {return (ValueStack) req.getAttribute(STRUTS_VALUESTACK_KEY);}/*** Gets the action mapping for this context** @return The action mapping*/public static ActionMapping getActionMapping() {return (ActionMapping) ActionContext.getContext().get(ACTION_MAPPING);}/*** Returns the HTTP page context.** @return the HTTP page context.*/public static PageContext getPageContext() {return (PageContext) ActionContext.getContext().get(PAGE_CONTEXT);}/*** Sets the HTTP servlet request object.** @param request the HTTP servlet request object.*/public static void setRequest(HttpServletRequest request) {ActionContext.getContext().put(HTTP_REQUEST, request);}/*** Gets the HTTP servlet request object.** @return the HTTP servlet request object.*/public static HttpServletRequest getRequest() {return (HttpServletRequest) ActionContext.getContext().get(HTTP_REQUEST);}/*** Sets the HTTP servlet response object.** @param response the HTTP servlet response object.*/public static void setResponse(HttpServletResponse response) {ActionContext.getContext().put(HTTP_RESPONSE, response);}/*** Gets the HTTP servlet response object.** @return the HTTP servlet response object.*/public static HttpServletResponse getResponse() {return (HttpServletResponse) ActionContext.getContext().get(HTTP_RESPONSE);}/*** Gets the servlet context.** @return the servlet context.*/public static ServletContext getServletContext() {return (ServletContext) ActionContext.getContext().get(SERVLET_CONTEXT);}/*** Sets the current servlet context object** @param servletContext The servlet context to use*/public static void setServletContext(ServletContext servletContext) {ActionContext.getContext().put(SERVLET_CONTEXT, servletContext);}
}


eg:

public class UserAction extends ActionSupport{private HttpServletRequest request;public String Login(){request = ServletActionContext.getRequest();//request的获得必须在具体的方法中实现  String name = request.getParameter("username");request.setAttribute("username", "张三");return "success";}}

ServletActionContext和ActionContext有着一些重复的功能,在我们的Action中,该如何去抉择呢? 我们遵循的原则是:如果ActionContext能够实现我们的功能,那最好就不要使用ServletActionContext,让我们的Action尽量不要直接去访问Servlet的相关对象.
注意:在使用ActionContext时有一点要注意: 不要在Action的构造函数里使用ActionContext.getContext(),因为这个时候ActionContext里的一些值也许没有设置,这时通过ActionContext取得的值也许是null;同样,HttpServletRequest req = ServletActionContext.getRequest()也不要放在构造函数中,也不要直接将req作为类变量给其赋值。至于原因,在ActionContext类中actionContext对象的创建为:   static ThreadLocal actionContext = new ActionContextThreadLocal(),ActionContextThreadLocal是实现ThreadLocal的一个内部类.ThreadLocal可以命名为"线程局部变量",它为每一个使用该变量的线程都提供一个变量值的副本,使每一个线程都可以独立地改变自己的副本,而不会和其它线程的副本冲突.这样,我们ActionContext里的属性只会在对应的当前请求线程中可见,从而保证它是线程安全的。ActionContext是线程安全的,而ServletActionContext继承自ActionContext,所以ServletActionContext也线程安全,线程安全要求每个线程都独立进行,所以req的创建也要求独立进行,所以ServletActionContext.getRequest()这句话不要放在构造函数中,也不要直接放在类中,而应该放在每个具体的方法体中(eg:login()、query()、insert()等),这样才能保证每次产生对象时独立的建立了一个req。 

 

这篇关于Struts2获取request、session、application的三种方法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1046743

相关文章

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

浅谈主机加固,六种有效的主机加固方法

在数字化时代,数据的价值不言而喻,但随之而来的安全威胁也日益严峻。从勒索病毒到内部泄露,企业的数据安全面临着前所未有的挑战。为了应对这些挑战,一种全新的主机加固解决方案应运而生。 MCK主机加固解决方案,采用先进的安全容器中间件技术,构建起一套内核级的纵深立体防护体系。这一体系突破了传统安全防护的局限,即使在管理员权限被恶意利用的情况下,也能确保服务器的安全稳定运行。 普适主机加固措施:

webm怎么转换成mp4?这几种方法超多人在用!

webm怎么转换成mp4?WebM作为一种新兴的视频编码格式,近年来逐渐进入大众视野,其背后承载着诸多优势,但同时也伴随着不容忽视的局限性,首要挑战在于其兼容性边界,尽管WebM已广泛适应于众多网站与软件平台,但在特定应用环境或老旧设备上,其兼容难题依旧凸显,为用户体验带来不便,再者,WebM格式的非普适性也体现在编辑流程上,由于它并非行业内的通用标准,编辑过程中可能会遭遇格式不兼容的障碍,导致操

透彻!驯服大型语言模型(LLMs)的五种方法,及具体方法选择思路

引言 随着时间的发展,大型语言模型不再停留在演示阶段而是逐步面向生产系统的应用,随着人们期望的不断增加,目标也发生了巨大的变化。在短短的几个月的时间里,人们对大模型的认识已经从对其zero-shot能力感到惊讶,转变为考虑改进模型质量、提高模型可用性。 「大语言模型(LLMs)其实就是利用高容量的模型架构(例如Transformer)对海量的、多种多样的数据分布进行建模得到,它包含了大量的先验

【北交大信息所AI-Max2】使用方法

BJTU信息所集群AI_MAX2使用方法 使用的前提是预约到相应的算力卡,拥有登录权限的账号密码,一般为导师组共用一个。 有浏览器、ssh工具就可以。 1.新建集群Terminal 浏览器登陆10.126.62.75 (如果是1集群把75改成66) 交互式开发 执行器选Terminal 密码随便设一个(需记住) 工作空间:私有数据、全部文件 加速器选GeForce_RTX_2080_Ti

【VUE】跨域问题的概念,以及解决方法。

目录 1.跨域概念 2.解决方法 2.1 配置网络请求代理 2.2 使用@CrossOrigin 注解 2.3 通过配置文件实现跨域 2.4 添加 CorsWebFilter 来解决跨域问题 1.跨域概念 跨域问题是由于浏览器实施了同源策略,该策略要求请求的域名、协议和端口必须与提供资源的服务相同。如果不相同,则需要服务器显式地允许这种跨域请求。一般在springbo

AI(文生语音)-TTS 技术线路探索学习:从拼接式参数化方法到Tacotron端到端输出

AI(文生语音)-TTS 技术线路探索学习:从拼接式参数化方法到Tacotron端到端输出 在数字化时代,文本到语音(Text-to-Speech, TTS)技术已成为人机交互的关键桥梁,无论是为视障人士提供辅助阅读,还是为智能助手注入声音的灵魂,TTS 技术都扮演着至关重要的角色。从最初的拼接式方法到参数化技术,再到现今的深度学习解决方案,TTS 技术经历了一段长足的进步。这篇文章将带您穿越时

模版方法模式template method

学习笔记,原文链接 https://refactoringguru.cn/design-patterns/template-method 超类中定义了一个算法的框架, 允许子类在不修改结构的情况下重写算法的特定步骤。 上层接口有默认实现的方法和子类需要自己实现的方法

Android Environment 获取的路径问题

1. 以获取 /System 路径为例 /*** Return root of the "system" partition holding the core Android OS.* Always present and mounted read-only.*/public static @NonNull File getRootDirectory() {return DIR_ANDR

使用JS/Jquery获得父窗口的几个方法(笔记)

<pre name="code" class="javascript">取父窗口的元素方法:$(selector, window.parent.document);那么你取父窗口的父窗口的元素就可以用:$(selector, window.parent.parent.document);如题: $(selector, window.top.document);//获得顶级窗口里面的元素 $(