JavaWeb项目快速入门04之拦截器,HandlerInterceptor拦截器最常用的就是登录和权限部分。
SpringBoot中的HandlerInterceptor常常用于拦截非法访问,比如未登录不能访问主页。如果未登录访问index.html,则跳转到登录页面。
创建包:InterInterceptor,并创建LoginlnterInterceptor实现HandlerInterceptor。主要是在prehandle方法里面实现登录验证:判断Session里面有没有登录者信息,如果有,则说明合法操作;如果没有则是不合法的,跳转到登录界面。另外增加login.html页面。
添加完拦截器,需要配置使其生效。通过WebMvcConfigurer接口完成,另外自行补充学习MVC。具体如下:
重启项目,不管访问任何url都会跳转到登录页面。如有报错,仔细对照Demo代码,学会调试。
完善登录相关逻辑:用户输入用户名密码,点击登录。成功则实现跳转,失败则提示错误。参照Demo完成。
注:如果出现302一直跳转到登录,检查是否配置拦截器跳过login方法
完善原来login方法,使其返回状态码。
自行补充学习前端基础知识(后期)。
查看是否实现登录成功跳转首页,未登录无法进入其他url。
另外补充学习:理论上,如果已经登录,再访问登录页面应该使其跳转到首页,自己试试如何实现。
之前我们把配置都直接写在代码里。根据高内聚,低耦合思想。把配置信息直接写死在代码里面显然是不明智的选择。如果要增加新的功能如注册,还需要追加白名单到数组进行配置。
(1) 修改application.yml 配置auth。增加whitelist数组,在yml里面应用 - 标记
(2) 修改LoginInterceptor实现读取配置login,与之前读取数据库配置类似
(3) 修改MvcConfig读取白名单路径:首先声明变量,存放whitelist。必须与配置文件中同名。然后添加注解:@ConfigurationProperties(prefix = "application.auth"),该注解是告诉Spring,刚才定义的变量是与yml中的配置相匹配。那么问题来了,excludePathPatterns中既有login,又有whitelist怎么办。这里用展开操作符(*)解决,具体可参考groovy语法 http://www.groovy-lang.org/operators.html 。
当登录失败时,我们返回的信息太多,抛出500错误。不想抛出这么多信息,或者封装之后再抛出,则用全局错误拦截器。
编辑:孙小北
本文地址: https://www.xiaowangyun.com/wyblog/detail/?id=1138
版权归属: www.xiaowangyun.com 转载时请以链接形式注明出处
0 条评论