电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

Java 使用Filter實現用戶自動登陸

瀏覽:26日期:2022-08-13 09:31:27
前言

安全,是如今互聯網行業特別注重的一個話題。在大家學習了JavaWeb之后呢,發現一個網站應該有安全限制,例如:如果用戶未登錄,則不允許相關CRUD操作,而如果我們在后臺的每一個Servlet都進行判斷,將降低系統效率,也會出現大量代碼冗余。因此,就有了Filter過濾器。

1、什么是Filter

Filter,過濾器,是處于客戶端與服務器資源文件之間的一道過濾網,在訪問資源文件之前,通過一系列的過濾器對請求進行修改、判斷等,把不符合規則的請求在中途攔截或修改。也可以對響應進行過濾,攔截或修改響應。

Java 使用Filter實現用戶自動登陸

2、過濾器實現攔截過程 當客戶端向服務器發送請求后,在HttpServletRequest到達Servlet之前,過濾器對HTTPServletRequest進行攔截 根據web.xml里的配置對請求攔截檢查,也可以修改請求頭和數據; 在過濾器中調用doFilter()方法,對請求放行(==注意==:必須調用doFilter方法,否則不往下執行)。 請求到達Servlet后,對請求進行處理并產生HttpServletResponse發送給客戶端。 在HttpServletResponse到達客戶端之前,過濾器也可以攔截響應; 根據需要檢查HttpServletResponse,同樣可以修改; 最后,HttpServletResponse到達客戶端。 3、過濾器與攔截器的不同之處1.過濾器:

依賴于servlet容器。在實現上基于函數回調,可以對幾乎所有請求進行過濾,但是缺點是一個過濾器實例只能在容器初始化時調用一次。使用過濾器的目的是用來做一些過濾操作,獲取我們想要獲取的數據,比如:在過濾器中修改字符編碼;在過濾器中修改HttpServletRequest的一些參數,包括:過濾低俗文字、危險字符等

2.攔截器:

依賴于web框架,在SpringMVC中就是依賴于SpringMVC框架。在實現上基于Java的反射機制,屬于面向切面編程(AOP)的一種運用。由于攔截器是基于web框架的調用,因此可以使用Spring的依賴注入(DI)進行一些業務操作,同時一個攔截器實例在一個controller生命周期之內可以多次調用。但是缺點是只能對controller請求進行攔截,對其他的一些比如直接訪問靜態資源的請求則沒辦法進行攔截處理

3.兩者的區別:

①攔截器是基于java的反射機制的,而過濾器是基于函數回調。

②攔截器不依賴與servlet容器,過濾器依賴與servlet容器。

③攔截器只能對action請求起作用,而過濾器則可以對幾乎所有的請求起作用。

④攔截器可以訪問action上下文、值棧里的對象,而過濾器不能訪問。

⑤在action的生命周期中,攔截器可以多次被調用,而過濾器只能在容器初始化時被調用一次。

⑥攔截器可以獲取IOC容器中的各個bean,而過濾器就不行,這點很重要,在攔截器里注入一個service,可以調用業務邏輯。

4、使用Filter實現用戶自動登陸

自動登錄,第一次訪問Servlet1,服務器會發送一個包含用戶信息的Cookie,之后當客戶端再次訪問服務器時,會向服務器回送Cookie,服務器就可以從Cookie中獲取用戶信息實現自動登錄。

問題:所有的Servlet都要對用于的Cookie信息進行校驗,導致Serlvet2Servlet3等出現大量冗余代碼。

解決:用Filter實現Cookie校驗用戶信息。

登錄表單

<%@ page contentType='text/html;charset=UTF-8' language='java' %>

登錄表單

Java 使用Filter實現用戶自動登陸

登錄控制器

package com.gxuwz.servlet;import com.gxuwz.po.User;import javax.servlet.ServletException;import javax.servlet.annotation.WebServlet;import javax.servlet.http.Cookie;import javax.servlet.http.HttpServlet;import javax.servlet.http.HttpServletRequest;import javax.servlet.http.HttpServletResponse;import java.io.IOException;@WebServlet('/LoginServlet3')public class LoginServlet3 extends HttpServlet { @Override protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {String username = req.getParameter('username');String password = req.getParameter('password');if ('admin'.equals(username)&&'123456'.equals(password)) { User user = new User(); user.setUsername(username); user.setPassword(password); req.getSession().setAttribute('USER_SESSION',user); String autoLogin = req.getParameter('autoLogin'); if (autoLogin!=null&&!' '.equals(autoLogin)) {//實際中應當對密碼進行加密!Cookie cookie = new Cookie('autoLogin', username + '-'+password);cookie.setMaxAge(Integer.parseInt(autoLogin));cookie.setPath(req.getContextPath());resp.addCookie(cookie); } resp.sendRedirect(req.getContextPath()+'/index.jsp');}else{ req.setAttribute('errorMsg','用戶名或者密碼錯誤!'); req.getRequestDispatcher('/login.jsp').forward(req,resp);} }}

過濾器實現自動登錄

package com.gxuwz.filter;import com.gxuwz.po.User;import javax.servlet.*;import javax.servlet.annotation.WebFilter;import javax.servlet.http.Cookie;import javax.servlet.http.HttpServletRequest;import javax.servlet.http.HttpServletResponse;import java.io.IOException;@WebFilter('/*')public class AutoFilter implements Filter { @Override public void init(FilterConfig filterConfig) throws ServletException { } @Override public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {HttpServletRequest req = (HttpServletRequest) request;HttpServletResponse resp = (HttpServletResponse) response;String autoLogin = '';Cookie[] cookies = req.getCookies();for (Cookie cookie : cookies) { if ('autoLogin'.equals(cookie.getName())){autoLogin=cookie.getValue();break; }}if (autoLogin!=null) { String[] parts = autoLogin.split('-'); String username = parts[0]; String password = parts[1]; if ('admin'.equals(username)&&'123456'.equals(password)) {User user = new User();user.setUsername(username);user.setPassword(password);req.getSession().setAttribute('USER_SESSION',user); }}chain.doFilter(req, resp); } @Override public void destroy() { }}<%@ page language='java' contentType='text/html; charset=utf-8'pageEncoding='utf-8' import='java.util.*'%><%@ taglib prefix='c' uri='http://java.sun.com/jsp/jstl/core'%><html><head><title>顯示登錄的用戶信息</title></head><body> <br /> <center><h3>歡迎光臨</h3> </center> <br /> <br /> <c:choose><c:when test='${sessionScope.user==null }'> <a href='http://www.hdgsjgj.cn/bcjs/${pageContext.request.contextPath }/login.jsp' rel='external nofollow' >用戶登錄</a></c:when><c:otherwise> 歡迎你,${sessionScope.user.username } <a href='http://www.hdgsjgj.cn/bcjs/${pageContext.request.contextPath }/LogoutServlet' rel='external nofollow' >退出</a></c:otherwise> </c:choose> <hr /></body></html><?xml version='1.0' encoding='UTF-8'?><web-app xmlns:xsi='http://www.w3.org/2001/XMLSchema-instance' xmlns='http://java.sun.com/xml/ns/javaee' xsi:schemaLocation='http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd' version='2.5'> <display-name>Project01</display-name> <welcome-file-list> <welcome-file>index.jsp</welcome-file> </welcome-file-list> <servlet> <description></description> <display-name>LogoutServlet</display-name> <servlet-name>LogoutServlet</servlet-name> <servlet-class>com.Servlet.LogoutServlet</servlet-class> </servlet> <servlet-mapping> <servlet-name>LogoutServlet</servlet-name> <url-pattern>/LogoutServlet</url-pattern> </servlet-mapping> <servlet> <description></description> <display-name>LoginServlet</display-name> <servlet-name>LoginServlet</servlet-name> <servlet-class>com.Servlet.LoginServlet</servlet-class> </servlet> <servlet-mapping> <servlet-name>LoginServlet</servlet-name> <url-pattern>/LoginServlet</url-pattern> </servlet-mapping> <filter> <display-name>AutoLoginFilter</display-name> <filter-name>AutoLoginFilter</filter-name> <filter-class>com.Filter.AutoLoginFilter</filter-class> </filter> <filter-mapping> <filter-name>AutoLoginFilter</filter-name> <!-- 攔截所有用戶請求 --> <url-pattern>/*</url-pattern> </filter-mapping></web-app>5、測試

輸入http://localhost/Project01/login.jsp

Java 使用Filter實現用戶自動登陸

關閉瀏覽器后,再次打開瀏覽器輸入http://localhost/Project01/index.jsp

Java 使用Filter實現用戶自動登陸

以上就是Java 使用Filter實現用戶自動登陸的詳細內容,更多關于Java 用Filter實現自動登陸的資料請關注好吧啦網其它相關文章!

標簽: Java
相關文章:
主站蜘蛛池模板: 广州展览设计公司_展台设计搭建_展位设计装修公司-众派展览装饰 广州展览制作工厂—[优简]直营展台制作工厂_展会搭建资质齐全 | 免费个人pos机申请办理-移动pos机刷卡-聚合收款码办理 | IWIS链条代理-ALPS耦合透镜-硅烷预处理剂-上海顶楚电子有限公司 lcd条形屏-液晶长条屏-户外广告屏-条形智能显示屏-深圳市条形智能电子有限公司 | 深圳办公室装修,办公楼/写字楼装修设计,一级资质 - ADD写艺 | 浙江建筑资质代办_二级房建_市政_电力_安许_劳务资质办理公司 | YT保温材料_YT无机保温砂浆_外墙保温材料_南阳银通节能建材高新技术开发有限公司 | 台式恒温摇床价格_大容量恒温摇床厂家-上海量壹科学仪器有限公司 | 房车价格_依维柯/大通/东风御风/福特全顺/江铃图片_云梯搬家车厂家-程力专用汽车股份有限公司 | 户外健身路径_小区健身器材_室外健身器材厂家_价格-浩然体育 | 心得体会网_心得体会格式范文模板 | 高温热泵烘干机,高温烘干热泵,热水设备机组_正旭热泵 | 附着力促进剂-尼龙处理剂-PP处理剂-金属附着力处理剂-东莞市炅盛塑胶科技有限公司 | SDI车窗夹力测试仪-KEMKRAFT方向盘测试仪-上海爱泽工业设备有限公司 | 流程管理|流程管理软件|企业流程管理|微宏科技-AlphaFlow_流程管理系统软件服务商 | 大连海岛旅游网>>大连旅游,大连海岛游,旅游景点攻略,海岛旅游官网 | pbt头梳丝_牙刷丝_尼龙毛刷丝_PP塑料纤维合成毛丝定制厂_广州明旺 | 北京公司注册_代理记账_代办商标注册工商执照-企力宝 | 宿舍管理系统_智慧园区系统_房屋/房产管理系统_公寓管理系统 | 进口试验机价格-进口生物材料试验机-西安卡夫曼测控技术有限公司 | 全自动五线打端沾锡机,全自动裁线剥皮双头沾锡机,全自动尼龙扎带机-东莞市海文能机械设备有限公司 | 仿古建筑设计-仿古建筑施工-仿古建筑公司-汉匠古建筑设计院 | LINK FASHION 童装·青少年装展| 无缝方管|无缝矩形管|无缝方矩管|无锡方管厂家 | 郑州巴特熔体泵有限公司专业的熔体泵,熔体齿轮泵与换网器生产厂家 | 环讯传媒,永康网络公司,永康网站建设,永康小程序开发制作,永康网站制作,武义网页设计,金华地区网站SEO优化推广 - 永康市环讯电子商务有限公司 | 欧美日韩国产一区二区三区不_久久久久国产精品无码不卡_亚洲欧洲美洲无码精品AV_精品一区美女视频_日韩黄色性爱一级视频_日本五十路人妻斩_国产99视频免费精品是看4_亚洲中文字幕无码一二三四区_国产小萍萍挤奶喷奶水_亚洲另类精品无码在线一区 | 专业生物有机肥造粒机,粉状有机肥生产线,槽式翻堆机厂家-郑州华之强重工科技有限公司 | 北京中创汇安科贸有限公司 | 一礼通 (www.yilitong.com)-企业礼品解决方案一站式服务平台 | 荣事达手推洗地机_洗地机厂家_驾驶式扫地机_工业清洁设备 | 家德利门业,家居安全门,别墅大门 - 安徽家德利门业有限公司 | VI设计-LOGO设计公司-品牌设计公司-包装设计公司-导视设计-杭州易象设计 | 欧盟ce检测认证_reach检测报告_第三方检测中心-深圳市威腾检验技术有限公司 | 玉米深加工设备-玉米深加工机械-新型玉米工机械生产厂家-河南粮院机械制造有限公司 | 液氮罐_液氮容器_自增压液氮罐_杜瓦瓶_班德液氮罐厂家 | 闸阀_截止阀_止回阀「生产厂家」-上海卡比阀门有限公司 | 船用烟火信号弹-CCS防汛救生圈-船用救生抛绳器(海威救生设备) | 不锈钢轴流风机,不锈钢电机-许昌光维防爆电机有限公司(原许昌光维特种电机技术有限公司) | 定做大型恒温循环水浴槽-工业用不锈钢恒温水箱-大容量低温恒温水槽-常州精达仪器 | 心肺复苏模拟人|医学模型|急救护理模型|医学教学模型上海康人医学仪器设备有限公司 | 破碎机锤头_耐磨锤头_合金锤头-鼎成机械一站式耐磨铸件定制服务 微型驱动系统解决方案-深圳市兆威机电股份有限公司 |