這篇文章主要為大家詳細介紹了怎么在Java中實現session過期后自動跳轉到登陸頁功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,發現的小伙伴們可以參考一下:
成都創新互聯公司服務緊隨時代發展步伐,進行技術革新和技術進步,經過10年的發展和積累,已經匯集了一批資深網站策劃師、設計師、專業的網站實施團隊以及高素質售后服務人員,并且完全形成了一套成熟的業務流程,能夠完全依照客戶要求對網站進行做網站、成都網站設計、建設、維護、更新和改版,實現客戶網站對外宣傳展示的首要目的,并為客戶企業品牌互聯網化提供全面的解決方案。
Java是一門面向對象編程語言,可以編寫桌面應用程序、Web應用程序、分布式系統和嵌入式系統應用程序。
一、建立基本過濾器
建立一個過濾器涉及下列五個步驟:
1)建立一個實現Filter接口的類SessionFilter。這個類需要三個方法,分別是:doFilter、init和destroy。doFilter方法包含主要的過濾代碼,init方法建立設置操作,而destroy方法進行清除。
2)在doFilter方法中放入過濾行為。doFilter方法的第一個參數為ServletRequest對象。此對象給過濾器提供了對進入的信息(包括表單數據、cookie和HTTP請求頭)的完全訪問。第二個參數為ServletResponse,通常在簡單的過濾器中忽略此參數。最后一個參數為FilterChain,如下一步所述,此參數用來調用servlet或JSP頁。
3)調用SessionFilter 對象的doFilter方法。Filter接口的doFilter方法取一個FilterChain對象作為它的一個參數。在調用此對象的doFilter方法時,激活下一個相關的過濾器。如果沒有另一個過濾器與servlet或JSP頁面關聯,則servlet或JSP頁面被激活。
4)對相應的servlet和JSP頁面注冊過濾器。在部署描述符文件(web.xml)中使用filter和filter-mapping元素。
5)禁用激活器servlet。防止用戶利用缺省servlet URL繞過過濾器設置。
源碼如下:
package com.base.filter; import java.io.IOException; 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; import com.base.constants.SessionKeyConstants; import com.mvc.entity.User; public class SessionFilter implements Filter { public void destroy() { // 過濾器銷毀,一般是釋放資源 } /** * 某些url需要登陸才能訪問(session驗證過濾器) */ public void doFilter(ServletRequest arg0, ServletResponse arg1, FilterChain arg2) throws IOException, ServletException { HttpServletRequest request = (HttpServletRequest) arg0; HttpServletResponse response = (HttpServletResponse) arg1; HttpSession session = request.getSession(); //判斷session是否過期 if ((User) session.getAttribute(SessionKeyConstants.LOGIN) == null) { String errors = "您還沒有登錄,或者session已過期。請先登陸!"; request.setAttribute("Message", errors); //跳轉至登錄頁面 request.getRequestDispatcher("/login.jsp").forward(request, response); } else { arg2.doFilter(request, response); } } public void init(FilterConfig arg0) throws ServletException { // 初始化操作,讀取web.xml中過濾器配置的初始化參數,滿足你提的要求不用此方法 } }
二、在web.xml配置文件中進行配置
<!-- 設置session過期時間為30分鐘 --> <session-config> <session-timeout>30</session-timeout> </session-config> <!-- session過濾器配置相關 --> <filter> <filter-name>SessionFilter</filter-name> <filter-class>com.base.filter.SessionFilter</filter-class> </filter> <filter-mapping> <filter-name>SessionFilter</filter-name> <url-pattern>/contract/*</url-pattern> <url-pattern>/user/*</url-pattern> <dispatcher>FORWARD</dispatcher> <!--在這種情況下,如果請求是以/contract/…或者/user/…開頭的,并且是通過request dispatcher的forward方法傳遞過來或者直接從客戶端傳遞過來的,則必須經過這個過濾器。--> <dispatcher>REQUEST</dispatcher> </filter-mapping>
以上就是創新互聯小編為大家收集整理的怎么在Java中實現session過期后自動跳轉到登陸頁功能,如何覺得創新互聯網站的內容還不錯,歡迎將創新互聯網站推薦給身邊好友。
本文標題:怎么在Java中實現session過期后自動跳轉到登陸頁功能
網站URL:http://m.kartarina.com/article14/jeopge.html
成都網站建設公司_創新互聯,為您提供定制開發、App開發、網站維護、、做網站、品牌網站設計
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯