几种获取request,session方法

本文介绍了在Struts2框架中获取request、session和application对象的三种方法:通过ActionContext、实现特定接口及使用ServletActionContext。每种方法都提供了具体的代码示例。
struts2中几种获得request,session等对象的方法 
1、通过ActionContext来获得举例代码如下: 

  情况1: 

   ActionContext context = ActionContext.getContext(); 
   Map request = (Map) context.get("request"); 
   Map session = context.getSession(); 
   Map application = context.getApplication(); 

情况2: 

  ActionContext actionContext = ActionContext.getContext(); 
  HttpServletRequest request = (HttpServletRequest) actionContext 
     .get(ServletActionContext.HTTP_REQUEST); 
   HttpSession session = request.getSession(); 
   ServletContext context = (ServletContext) actionContext 
     .get(ServletActionContext.SERVLET_CONTEXT); 



2、通过实现 RequestAware, SessionAware,ApplicationAware等接口来获得,举例代码如下: 

public class LoginAction2 implements Action, RequestAware, SessionAware, 
  ApplicationAware { 

   private Map request; 
   private Map session; 
   private Map application; 

   public void setRequest(Map request) { 
         this.request = request; 
  } 

   public void setSession(Map session) { 
        this.session = session; 
  } 

  public void setApplication(Map application) { 
             this.application = application; 
  } 

} 

3、通过ServletActionContext来获得,举例代码如下: 

   // 利用ServletActionContext获得request 
   HttpServletRequest request = ServletActionContext.getRequest(); 
   // 利用request获得session 
   HttpSession session = request.getSession(); 
   // 利用ServletActionContext获得servletContext 
   ServletContext context = ServletActionContext.getServletContext();
### HTTP RequestSession 的存储位置 Session 是一种用于跟踪用户状态的技术,在 Web 开发中被广泛使用。尽管 `request.getSession()` 方法可以用来获取当前用户的 Session 对象,但实际上 Session 并不是直接存储在请求对象中的。 #### Session 的实际存储位置 Session 数据通常由服务器管理并保存在一个特定的位置,而客户端仅持有与该 Session 关联的一个唯一标识符(通常是名为 JSESSIONID 或类似的 Cookie)。以下是常见的几种 Session 存储方式: 1. **内存存储** 许多应用服务器默认将 Session 数据存储在内存中。这种方式简单高效,但在分布式环境中可能会遇到问题,因为不同的节点可能无法共享同一份内存数据[^1]。 2. **文件系统存储** 某些框架允许将 Session 数据序列化到磁盘上的文件中。这种方法适合小型项目或单机部署场景,但对于高并发环境性能较差[^3]。 3. **数据库存储** 将 Session 数据持久化至关系型数据库或其他类型的 NoSQL 数据库是一种常见做法。它能够提供更高的可靠性和跨多个实例的一致性支持[^4]。 4. **缓存服务存储** 使用 Redis、Memcached 等高性能键值对存储作为 Session 后端成为现代架构下的主流选择之一。这种方案不仅速度快而且易于扩展。 #### 如何访问 Session 数据? 要读取或者写入 Session 数据,可以通过编程接口实现。不同语言和技术栈有不同的方法来处理这些操作。下面是一些例子: - **Java Servlet API** ```java HttpSession session = request.getSession(); String value = (String) session.getAttribute("key"); session.setAttribute("anotherKey", anotherValue); ``` - **PHP** PHP 自动通过超全局数组 $_SESSION 提供了便捷的方式去管理和检索会话变量。 ```php <?php session_start(); // 别忘了启动会话机制哦! $_SESSION['username'] = 'JohnDoe'; echo $_SESSION['username']; ?> ``` - **Python Django Framework** 在 Django 应用程序里配置好 SESSION_ENGINE 参数之后就可以轻松地设置和取得 session 值啦。 ```python from django.http import HttpRequest def my_view(request:HttpRequest): request.session['my_key']='hello world' data=request.session.get('my_key') return HttpResponse(data) ``` 另外需要注意的是当涉及到安全性考量时应该采取措施保护敏感信息不泄露给未经授权的人士比如加密传输过程以及定期清理过期记录等等[^2].
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值