本文研究的主要是Struts攔截器實(shí)現(xiàn)攔截未登陸用戶(hù),具體實(shí)現(xiàn)如下。

首先建立一個(gè)工具類(lèi):
checkPrivilegeInterceptor:這個(gè)類(lèi)繼承interceptor,這是一個(gè)接口,要實(shí)現(xiàn)三個(gè)方法,要是覺(jué)得比較多的話(huà),可以繼承他的實(shí)現(xiàn)類(lèi)AbstractInterceptor,繼承這個(gè)類(lèi)以后只需要重寫(xiě)一個(gè)方法,就是在這個(gè)方法里面控制,是否登錄,登錄以后有哪些權(quán)限,等等,代碼如下;
package com.cjdx.utils;
import javax.annotation.Resource;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import com.cjdx.domain.User;
import com.opensymphony.xwork2.ActionContext;
import com.opensymphony.xwork2.ActionInvocation;
import com.opensymphony.xwork2.interceptor.AbstractInterceptor;
//檢查是否有權(quán)限,這里只檢查知否登錄
public class CheckPrivilegeInterceptor extends AbstractInterceptor {
@Override
public String intercept(ActionInvocation invocation) throws Exception {
User user = (User) ActionContext.getContext().getSession().get("user");
String nameSpace = invocation.getProxy().getNamespace();
String actionName = invocation.getProxy().getActionName();
String privilegeUrl = nameSpace + actionName;
if (user == null) {
// 如果用戶(hù)沒(méi)有登錄
if (privilegeUrl.startsWith("/user_login")) {
//如果用戶(hù)準(zhǔn)備去登錄,則放行
return invocation.invoke();
}
{
return "loginUI";
//如果用戶(hù)不是去登錄,又沒(méi)有登錄,則轉(zhuǎn)到登錄頁(yè)面
}
} else {
return invocation.invoke();
//如果用戶(hù)已經(jīng)登錄,則執(zhí)行相應(yīng)的方法
}
}
}
標(biāo)題名稱(chēng):Struts攔截器實(shí)現(xiàn)攔截未登陸用戶(hù)實(shí)例解析-創(chuàng)新互聯(lián)
網(wǎng)頁(yè)地址:http://chinadenli.net/article44/ejphe.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供定制開(kāi)發(fā)、虛擬主機(jī)、手機(jī)網(wǎng)站建設(shè)、面包屑導(dǎo)航、網(wǎng)站建設(shè)、網(wǎng)站設(shè)計(jì)公司
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話(huà):028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容