struts2访问web元素

取得Map类型的request、session、application、真实类型的HttpServletRequest、HttpSession、HttpServletApplication

第一种方式(解耦合):在Action中取得Map类型的request、session、application  依赖于容器的方式

public class LoginAction1 extends ActionSupport{

     private Map request;

     private Map session;

private Map application;

//构造函数

public LoginAction1(){

request = (Map)ActionContext.getContext().get("request");

//为什么直接在get里面填写request就可以取得Map类型的request了呢?这是为什么呢

//我们可以在jsp的页面上使用<s:debug>,就可以发现在debug中有两部分内容

//第一部分:Value stack(值栈) 其中包含的是一些Action中的属性、errors、fieldErrors、actionErrors等内容

//这些值可以在页面上用<s:property value="errors.name[0]"/>取出错误信息 或 <s:property value="action中的属性"/>

//第二部分:Stack Context 也就是ActionContext (action的上下文环境),其中就包括了许多的key和对应的value

//在key的取值中就有request,所以上面用get("request")的方式就会取到Map类型的request值

//还有一点需要注意,在页面上访问ActionContext中的值时需要使用 #key 的方式。

session = ActionContext.getContext().getSession();

application = ActionContext.getContext().getApplication();

}

public String execute(){

request.put("r1","r1");

session.put("s1","s1");

application.put("a1","a1");

request SUCCESS;

}

}

前台jsp页面访问时,可以这样来访问:

<s:property value="#request.r1"/> | <%=request.getAttribute("r1")%>

<s:property value="#session.s1"/> | <%=session.getAttribute("s1")%>

<s:property value="#application.a1"/> | <%=application.getAttribute("a1")%>

<s:property value="#attr.a1"/> //attr会自动搜索request,session,application范围搜索

 

第二种方式(低耦合): IOC方式

public class LoginAction2 extends ActionSupport implements RequestAware,SessionAware, ApplicationAware {
 
 private Map<String, Object> request;
 private Map<String, Object> session;
 private Map<String, Object> application;
 
 //DI dependency injection
 //IoC inverse of control
 public String execute() {
  request.put("r1", "r1");
  session.put("s1", "s1");
  application.put("a1", "a1");
  return SUCCESS; 
 }

 @Override
 public void setRequest(Map<String, Object> request) {
  this.request = request;
 }

 @Override
 public void setSession(Map<String, Object> session) {
  this.session = session;
 }

 @Override
 public void setApplication(Map<String, Object> application) {
  this.application = application;
 }


}

其中的aware(得知,知道的意思),需要重写对应的方法

第三种方法(高耦合):获得HttpServletRequest、HttpSession、HttpServletApplication 依赖于容器的方式

public class LoginAction3 extends ActionSupport {
 
 private HttpServletRequest request;
 private HttpSession session;
 private ServletContext application;
 
 public LoginAction3() {
  request = ServletActionContext.getRequest();
  session = request.getSession();
  application = session.getServletContext();
 }
 
 public String execute() {
  request.setAttribute("r1", "r1");
  session.setAttribute("s1", "s1");
  application.setAttribute("a1", "a1");
  return SUCCESS; 
 }
 
}


第四种方式(高耦合):获得HttpServletRequest、HttpSession、HttpServletApplication IOC方式

public class LoginAction4 extends ActionSupport implements ServletRequestAware {
 
 private HttpServletRequest request;
 private HttpSession session;
 private ServletContext application;

 
 public String execute() {
  request.setAttribute("r1", "r1");
  session.setAttribute("s1", "s1");
  application.setAttribute("a1", "a1");
  return SUCCESS; 
 }

 

 @Override
 public void setServletRequest(HttpServletRequest request) {
  this.request = request;
  this.session = request.getSession();
  this.application = session.getServletContext();
 }
 
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值