servlet+jsp實(shí)現(xiàn)過(guò)濾器 防止用戶未登錄訪問(wèn)
我們可能經(jīng)常會(huì)用到這一功能,比如有時(shí),我們不希望用戶沒(méi)有進(jìn)行登錄訪問(wèn)后臺(tái)的操作頁(yè)面,而且這樣的非法訪問(wèn)會(huì)讓系統(tǒng)極為的不安全,所以我們常常需要進(jìn)行登錄才授權(quán)訪問(wèn)其它頁(yè)面,否則只會(huì)出現(xiàn)登錄頁(yè)面,當(dāng)然我的思路:
一種是在jsp頁(yè)面進(jìn)行session的判斷,如果不存在該用戶的session,就跳轉(zhuǎn)到登錄頁(yè)面,否則執(zhí)行jsp頁(yè)面代碼,但是你會(huì)發(fā)現(xiàn)這樣做邏輯也簡(jiǎn)單,但是非常麻煩,如果有很多個(gè)jsp,那么就要寫多個(gè)判斷。
另一種則是利用過(guò)濾器,訪問(wèn)頁(yè)面時(shí)都進(jìn)行過(guò)濾驗(yàn)證,如果存在該用戶session,則訪問(wèn)該頁(yè)面,否則跳轉(zhuǎn)到登陸頁(yè)面登錄,保存session后訪問(wèn)其它頁(yè)面。
以下是我的實(shí)現(xiàn)
package com.test.filter; import java.io.IOException; import java.io.PrintWriter; import javax.servlet.FilterConfig; import javax.servlet.ServletException; import javax.servlet.Filter; import javax.servlet.FilterChain; import javax.servlet.ServletRequest; import javax.servlet.ServletResponse; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import javax.servlet.http.HttpSession; public class LoginFilter implements Filter { public static final String login_page = "/test/admin/index.jsp"; public static final String logout_page = "/test/admin/Public/login.jsp"; public void destroy(){ } public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain)throws ServletException, IOException { HttpServletRequest request = (HttpServletRequest)servletRequest; HttpServletResponse response = (HttpServletResponse)servletResponse; String currentURL = request.getRequestURI(); String ctxPath = request.getContextPath(); //除掉項(xiàng)目名稱時(shí)訪問(wèn)頁(yè)面當(dāng)前路徑 String targetURL = currentURL.substring(ctxPath.length()); HttpSession session = request.getSession(false); //對(duì)當(dāng)前頁(yè)面進(jìn)行判斷,如果當(dāng)前頁(yè)面不為登錄頁(yè)面 if(!("/admin/Public/login.jsp".equals(targetURL))){ System.out.println("1"+targetURL+"ctxPath:"+ctxPath+"currentURL:"+currentURL); //在不為登陸頁(yè)面時(shí),再進(jìn)行判斷,如果不是登陸頁(yè)面也沒(méi)有session則跳轉(zhuǎn)到登錄頁(yè)面, if(session == null || session.getAttribute("admin") == null){ response.sendRedirect(logout_page); return; }else{ //這里表示正確,會(huì)去尋找下一個(gè)鏈,如果不存在,則進(jìn)行正常的頁(yè)面跳轉(zhuǎn) filterChain.doFilter(request, response); return; } }else{ //這里表示如果當(dāng)前頁(yè)面是登陸頁(yè)面,跳轉(zhuǎn)到登陸頁(yè)面 filterChain.doFilter(request, response); return; } } public void init(FilterConfig filterConfig)throws ServletException{ } }
接下來(lái)在web.xml中進(jìn)行配置
<filter> <filter-name>LoginFilter</filter-name> <filter-class>com.test.filter.LoginFilter</filter-class> </filter> <filter-mapping> <filter-name>LoginFilter</filter-name> //這里表示對(duì)所有的以jsp后綴的文件有效,其它的無(wú)效 <url-pattern>*.jsp</url-pattern> </filter-mapping>
那么,這樣功能就實(shí)現(xiàn)了。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持我們。
欄 目:JSP編程
下一篇:Jsp中request的3個(gè)基礎(chǔ)實(shí)踐
本文標(biāo)題:servlet+jsp實(shí)現(xiàn)過(guò)濾器 防止用戶未登錄訪問(wèn)
本文地址:http://mengdiqiu.com.cn/a1/JSPbiancheng/11422.html
您可能感興趣的文章
- 01-11jsp文件下載功能實(shí)現(xiàn)代碼
- 01-11Spring獲取ApplicationContext對(duì)象工具類的實(shí)現(xiàn)方法
- 01-11web前端超出兩行用省略號(hào)表示的實(shí)現(xiàn)方法
- 01-11JSP servlet實(shí)現(xiàn)文件上傳下載和刪除
- 01-11jsp+servlet實(shí)現(xiàn)文件上傳與下載功能
- 01-11將properties文件的配置設(shè)置為整個(gè)Web應(yīng)用的全局變量實(shí)現(xiàn)方法
- 01-11秒殺系統(tǒng)Web層設(shè)計(jì)的實(shí)現(xiàn)方法
- 01-11Jsp+Servlet實(shí)現(xiàn)文件上傳下載 文件上傳(一)
- 01-11tomcat共享多個(gè)web應(yīng)用會(huì)話的實(shí)現(xiàn)方法
- 01-11Jsp+Servlet實(shí)現(xiàn)文件上傳下載 文件列表展示(二)


閱讀排行
- 1C語(yǔ)言 while語(yǔ)句的用法詳解
- 2java 實(shí)現(xiàn)簡(jiǎn)單圣誕樹的示例代碼(圣誕
- 3利用C語(yǔ)言實(shí)現(xiàn)“百馬百擔(dān)”問(wèn)題方法
- 4C語(yǔ)言中計(jì)算正弦的相關(guān)函數(shù)總結(jié)
- 5c語(yǔ)言計(jì)算三角形面積代碼
- 6什么是 WSH(腳本宿主)的詳細(xì)解釋
- 7C++ 中隨機(jī)函數(shù)random函數(shù)的使用方法
- 8正則表達(dá)式匹配各種特殊字符
- 9C語(yǔ)言十進(jìn)制轉(zhuǎn)二進(jìn)制代碼實(shí)例
- 10C語(yǔ)言查找數(shù)組里數(shù)字重復(fù)次數(shù)的方法
本欄相關(guān)
- 01-11web下載文件和跳轉(zhuǎn)的方法
- 01-11Spring注入Date類型的三種方法總結(jié)
- 01-11在JSP中使用formatNumber控制要顯示的小
- 01-11Properties 持久的屬性集的實(shí)例詳解
- 01-11EJB3.0部署消息驅(qū)動(dòng)Bean拋javax.naming.Na
- 01-11jsp文件下載功能實(shí)現(xiàn)代碼
- 01-11JSP頁(yè)面跳轉(zhuǎn)方法大全
- 01-11詳解Spring的核心機(jī)制依賴注入
- 01-11jsp 使用request為頁(yè)面添加靜態(tài)數(shù)據(jù)的實(shí)
- 01-11Spring獲取ApplicationContext對(duì)象工具類的
隨機(jī)閱讀
- 01-10使用C語(yǔ)言求解撲克牌的順子及n個(gè)骰子
- 01-11Mac OSX 打開(kāi)原生自帶讀寫NTFS功能(圖文
- 01-10delphi制作wav文件的方法
- 08-05織夢(mèng)dedecms什么時(shí)候用欄目交叉功能?
- 01-10SublimeText編譯C開(kāi)發(fā)環(huán)境設(shè)置
- 04-02jquery與jsp,用jquery
- 01-10C#中split用法實(shí)例總結(jié)
- 01-11ajax實(shí)現(xiàn)頁(yè)面的局部加載
- 08-05dedecms(織夢(mèng))副欄目數(shù)量限制代碼修改
- 08-05DEDE織夢(mèng)data目錄下的sessions文件夾有什