【JavaWeb】 目前主要更新JavaWeb,一起学习一起进步。
本期主要介绍案例:用户登录、用户自动登录
1 、点击登录按钮时,在服务器根据表单用户名和密码,判断是否登录成功(本案例不考虑登录失
败)
2、登录成功,将用户信息存入 session 作用域,请求转发到 index.jsp 展示信息
(详见老师课上讲解)
login.jsp
UserServlet
UserService
UserDao
index.jsp
登录成功后,重新打开浏览器时,index.jsp 上的登录状态就会消失,就会需要人工重新登录。
我们希望有一个程序,在我们打开 index.jsp 时,若我们之前就已经登录成功了,即使登录状态消
失了,也
能自动帮我们输入之前的用户名和密码,帮我们重新登录。
这就是自动登录。
帮助我们实现自动登录的载体,就是过滤器。
什么是过滤器(任何实现了 Filter 接口的实现类,都是过滤器)
过滤器是一个运行在服务器端的程序,先于与之相关的 servlet 或 JSP 页面之前运行,实现对请求
资源的过滤的功能。
登录:成功 ( session 作用域记录用户登录状态),失败(在 request 作用域记录用错误信息)
过滤器可附加到一个或多个 servlet 或 JSP 页面上,可以检查请求信息,也可以处理响应信息。
Filter 的基本功能是对 Servlet 容器调用 Servlet 的过程进行拦截,从而在 Servlet 执行前后实现
一些特殊的功能。
过滤器常用实例
自动登录,解决全站乱码,屏蔽非法文字,进行响应数据压缩,等等
过滤器入门案例:
访问这个项目的任意资源,都会先执行过滤器,再执行资源。
创建:随着项目启动而创建
销毁:随着项目关闭而销毁
目标资源:访问哪个资源 ,被过滤器拦截了,这个资源就是你的目标资源
放行:把请求继续向后传递,直至传递给目标资源
开发中我们会存在多个过滤器
根据 web.xml 中 <filter-mapping> 标签的放置顺序决定:从上到下依次执行
url-pattern 的配置与 servlet 中的配置一样:
servlet-name 的配置,通过 url-pattern 拦截一个 Servlet 的资源 . 也可以通过 servlet-name 标签进
行拦截.
dispatcher 的配置
FilterConfig 对象
UserServlet (修改 servlet ,让 servlet 在登录成功时,把用户名密码永久保存到 cookie 中,方便
过滤器进行自动登录)
web.xml 加入:(filter-class 路径自己设置)
AutoLoginFilter:(过滤器通过保存用户名密码的 cookie,进行自动登录)