婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 詳解Struts2中對未登錄jsp頁面實(shí)現(xiàn)攔截功能

詳解Struts2中對未登錄jsp頁面實(shí)現(xiàn)攔截功能

熱門標(biāo)簽:電話機(jī)器人需要使用網(wǎng)絡(luò)嗎 南通通訊外呼系統(tǒng)產(chǎn)品介紹 如何看懂地圖標(biāo)注點(diǎn) 自繪地圖標(biāo)注數(shù)據(jù) 海外圖書館地圖標(biāo)注點(diǎn) 外呼系統(tǒng)使用方法 潤滑油銷售電銷機(jī)器人 電銷機(jī)器人免培訓(xùn) 給地圖標(biāo)注得傭金

Struts2中攔截器大家都很經(jīng)常使用,但是攔截器只能攔截action不能攔截jsp頁面。這個時候就有點(diǎn)尷尬了,按道理來說沒登錄的用戶只能看login界面不能夠通過輸入URL進(jìn)行界面跳轉(zhuǎn),這顯然是不合理的。這里介紹Struts2中Filter實(shí)現(xiàn)jsp頁面攔截的功能。(有興趣的人可以去研究Filter過濾器的其它用法,因?yàn)槔眠^濾器也可以實(shí)現(xiàn)action攔截的功能)

下面直接上代碼,邊看邊分析實(shí)現(xiàn)步驟和原理。

1.web.xml中的配置信息:

filter>  
  filter-name>SessionInvalidate/filter-name>  
  filter-class>com.tp.action.SessionCheckFilter/filter-class> //過濾器核心類的class地址 
  init-param>  
   param-name>checkSessionKey/param-name> //session中需要檢查的key 
   param-value>users/param-value>  
  /init-param>  
  init-param>  
   param-name>redirectURL/param-name> //過濾重定向的地址 
   param-value>/login.jsp/param-value>  
  /init-param>  
  init-param>  
   param-name>notCheckURLList/param-name> //不需要過濾的jsp 
   param-value>/login.jsp/param-value>  
  /init-param>  
 /filter>  
 filter-mapping>  
  filter-name>SessionInvalidate/filter-name> //需要過濾的文件 
  url-pattern>*.jsp/url-pattern>  
 /filter-mapping> 

這里有幾點(diǎn)需要注意的是:

1.過濾器要盡量放在Struts2配置代碼的上面。

2.在SessionInvalidate中 url-pattern>*.jsp/url-pattern>  配置非常重要。*.jsp表示只過濾jsp的界面不會把css,js,action一起給過濾了。如果寫成/*就會把所有的東西一起過濾了。包括css,js,action等。所以這個地方一定要看仔細(xì)。

3.SessionCheckFilter過濾的核心類:

package com.tp.action; 
import java.io.IOException;  
import java.util.HashSet;  
import java.util.Set;  
import javax.servlet.Filter;  
import javax.servlet.FilterChain;  
import javax.servlet.FilterConfig;  
import javax.servlet.ServletException;  
import javax.servlet.ServletRequest;  
import javax.servlet.ServletResponse;  
import javax.servlet.http.HttpServletRequest;  
import javax.servlet.http.HttpServletResponse;  
import javax.servlet.http.HttpSession;  
/** 
 * 用于檢測用戶是否登陸的過濾器,如果未登錄,則重定向到指的登錄頁面 配置參數(shù) checkSessionKey 需檢查的在 Session 中保存的關(guān)鍵字 
 * redirectURL 如果用戶未登錄,則重定向到指定的頁面,URL不包括 ContextPath notCheckURLList 
 * 不做檢查的URL列表,以分號分開,并且 URL 中不包括 ContextPath 
 */  
public class SessionCheckFilter implements Filter {  
 protected FilterConfig filterConfig = null;  
 private String redirectURL = null;  
 private SetString> notCheckURLList = new HashSetString>();  
 private String sessionKey = null;  
 @Override  
 public void destroy() {  
  notCheckURLList.clear();  
 }  
 @Override  
 public void doFilter(ServletRequest servletRequest,  
   ServletResponse servletResponse, FilterChain filterChain)  
   throws IOException, ServletException {  
  HttpServletRequest request = (HttpServletRequest) servletRequest;  
  HttpServletResponse response = (HttpServletResponse) servletResponse;  
  HttpSession session = request.getSession();  
  if (sessionKey == null) {  
   filterChain.doFilter(request, response);  
   return;  
  }  
  if ((!checkRequestURIIntNotFilterList(request))  
     session.getAttribute("users") == null) {  
     response.sendRedirect(request.getContextPath() + redirectURL);  
   return;  
  }  
  filterChain.doFilter(servletRequest, servletResponse);  
 }  
 private boolean checkRequestURIIntNotFilterList(HttpServletRequest request) {  
  String uri = request.getServletPath()  
    + (request.getPathInfo() == null ? "" : request.getPathInfo());  
  String temp = request.getRequestURI(); 
  temp = temp.substring(request.getContextPath().length() + 1);  
  // System.out.println("是否包括:"+uri+";"+notCheckURLList+"=="+notCheckURLList.contains(uri));  
  return notCheckURLList.contains(uri);  
 }  
 @Override  
 public void init(FilterConfig filterConfig) throws ServletException {  
  this.filterConfig = filterConfig;  
  redirectURL = filterConfig.getInitParameter("redirectURL");  
  sessionKey = filterConfig.getInitParameter("checkSessionKey");  
  String notCheckURLListStr = filterConfig  
    .getInitParameter("notCheckURLList");  
  if (notCheckURLListStr != null) {  
   System.out.println(notCheckURLListStr);  
   String[] params = notCheckURLListStr.split(",");  
   for (int i = 0; i  params.length; i++) {  
    notCheckURLList.add(params[i].trim());  
   }  
  }  
 }  
} 

到這里過濾器的功能就實(shí)現(xiàn)了。再重申一下web.xml中配置的信息,需要好好檢查檢查因?yàn)槟抢锸沁^濾器是否成功的關(guān)鍵。

總結(jié)

本文關(guān)于詳解Struts2中對未登錄jsp頁面實(shí)現(xiàn)攔截功能的介紹就到這里,希望對大家有所幫助。歡迎參閱:struts2開發(fā)流程及詳細(xì)配置  Struts2修改上傳文件大小限制方法解析等。有什么問題可以隨時留言,小編會及時回復(fù)大家。感謝朋友們對腳本之家的支持。

您可能感興趣的文章:
  • 防止未登錄用戶操作—基于struts2攔截器的簡單實(shí)現(xiàn)
  • Struts2攔截器 關(guān)于解決登錄的問題
  • Struts2攔截器登錄驗(yàn)證實(shí)例
  • Struts2開發(fā)環(huán)境搭建 附簡單登錄功能實(shí)例
  • struts2與cookie 實(shí)現(xiàn)自動登錄和驗(yàn)證碼驗(yàn)證實(shí)現(xiàn)代碼
  • Java struts2 validate用戶登錄校驗(yàn)功能實(shí)現(xiàn)
  • 使用MyEclipse 開發(fā)struts2框架實(shí)現(xiàn)登錄功能(結(jié)構(gòu)教程)
  • JQuery+Ajax+Struts2+Hibernate框架整合實(shí)現(xiàn)完整的登錄注冊
  • struts2+jquery組合驗(yàn)證注冊用戶是否存在
  • 基于struts2和hibernate實(shí)現(xiàn)登錄和注冊功能

標(biāo)簽:大連 廣州 樂山 貸款邀約 銅川 黃石 內(nèi)江 南京

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《詳解Struts2中對未登錄jsp頁面實(shí)現(xiàn)攔截功能》,本文關(guān)鍵詞  詳解,Struts2,中,對,未,登錄,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《詳解Struts2中對未登錄jsp頁面實(shí)現(xiàn)攔截功能》相關(guān)的同類信息!
  • 本頁收集關(guān)于詳解Struts2中對未登錄jsp頁面實(shí)現(xiàn)攔截功能的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 鸡东县| 保康县| 武川县| 梧州市| 天峨县| 丁青县| 长治市| 称多县| 健康| 泸州市| 乌兰察布市| 万宁市| 宿州市| 杂多县| 永和县| 怀宁县| 运城市| 四会市| 肥东县| 广宗县| 阿城市| 乃东县| 维西| 股票| 贵港市| 郓城县| 苗栗市| 东光县| 托里县| 江安县| 岗巴县| 库尔勒市| 喀喇沁旗| 亚东县| 威信县| 汶川县| 哈尔滨市| 探索| 罗山县| 湾仔区| 五常市|