本文實例分析了jsp中Action使用session方法。分享給大家供大家參考。具體如下:
在Struts2里,如果需要在Action中使用session,可以通過下面兩種方式得到
1.通過ActionContext class中的方法getSession得到
2.Action實現(xiàn)org.apache.struts2.interceptor.SessionAware接口的方式來對session進(jìn)行操作
下面先看一個采用第一種方式,在action中得到session的例子
復(fù)制代碼 代碼如下:
package s2.ex.action;
import java.util.Map;
import com.opensymphony.xwork2.ActionContext;
import com.opensymphony.xwork2.ActionSupport;
public class SessionTestActionextends ActionSupport {
public String execute() {
ActionContext actionContext = ActionContext.getContext();
Map session = actionContext.getSession();
session.put("USER_NAME","Test User");
return SUCCESS;
}
}
在這個例子中,通過ActionContext得到session,并往session里放置一個key為USER_NAME,值為Test User的內(nèi)容。
下面是一個實現(xiàn)org.apache.struts2.interceptor.SessionAware接口來對session操作的例子
復(fù)制代碼 代碼如下:
package s2.ex.action;
import java.util.Map;
import org.apache.struts2.interceptor.SessionAware;
import com.opensymphony.xwork2.ActionSupport;
public class SessionTest1Action extends ActionSupport implements SessionAware {
private Map session;
publicvoid setSession(Map session) {
this.session = session;
}
public String execute() {
this.session.put("USER_NAME","Test User 1");
return SUCCESS;
}
}
在這個例子中實現(xiàn)了接口SessionAware中的setSession方法。
上面兩種方式都可以得到session,能實現(xiàn)的功能都是一樣的。
這里推薦通過第二種方式來使用session,原因是便于做單體測試,用第二種方式,只需要構(gòu)造一個Map就可以對actionclass進(jìn)行單體測試了。
在一個項目中可能會有很多action都需要用到session,如果每個action都來實現(xiàn) org.apache.struts2.interceptor.SessionAware這個接口,可能會顯得比較麻煩,所以建議作一個抽象的 BaseAction類來實現(xiàn)org.apache.struts2.interceptor.SessionAware接口,以后所有的action只要繼承這個BaseAction就可以了。
下面是一個如何在JSP中使用session的例子。
復(fù)制代碼 代碼如下:
%@ page contentType="text/html; charset=UTF-8" %>
%@page pageEncoding="utf-8" %>
%@taglib prefix="s" uri="/struts-tags" %>
html>
head>
title>Session Test/title>
/head>
body>
h1>s:property value="#session.USER_NAME"/>/h1>
/body>
/html>
一般在項目中往往會往session里放置一個Object,必如說user,user里有個booleanadmin和String userName,如果user里存在isAdmin的方法,在jsp中可以通過s:iftest="#session.user.admin">來判斷用戶有沒有管理權(quán)限,通過s:property value="#session.user.userName">或者來取得用戶名。
希望本文所述對大家的jsp程序設(shè)計有所幫助。
您可能感興趣的文章:- jsp編程中session的用法實例分析
- jsp獲取action傳來的session和session清空以及判斷
- jsp和asp.net共享session值示例代碼
- Jsp中解決session過期跳轉(zhuǎn)到登陸頁面并跳出iframe框架的方法
- JSP中 Session和作用域的使用
- jsp中session過期設(shè)置及web.xml配置學(xué)習(xí)
- jsp 對request.getSession(false)的理解(附程序員常疏忽的一個漏洞)
- jsp中存取session值簡單介紹