springboot:员工管理系统-登录拦截器实现

登录

    我们的数据库是虚假的,这里就先不通过数据库判断了,直接定死,后期在聊我会对应的去修改代码

    步骤

  1. 我们把登录页面的表单提交地址传到controller里面!
<form class="form-signin" th:action="@{user/login}">
  1. 里面的input标签肯定是也需要添加name属性的
<input type="text" class="form-control" name="username" th:placeholder="#{login.username}" required="" autofocus="">
			<input type="password" class="form-control" name="password" th:placeholder="#{login.password}" required="">
  1. 编写首页对应的controller页面
@Controller
public class loginController {

    @RequestMapping("/user/login")
    public String LoginController(@RequestParam("username")String username,
    @RequestParam("password") String password , 
    Model model){//接收前端传值,name

        //具体的业务:方法判断username是否为空,并且密码必须是123456
        if (!StringUtils.isEmpty(username) && "123456".equals(password)){
            return "redirect:/main.html";
        }else{
            //告诉用户,你登陆失败了!
            model.addAttribute("msg","用户名或者密码错误");
            return "index";
        }

    }

}

  1. 在首页的h1标签下面加个p标签,里面$链接msg,这样当我们登陆失败的时候会提示我们 用户名密码错误!
    在这里插入图片描述
  2. 测试
    在这里插入图片描述
    在这里插入图片描述
        测试成功!

    优化代码
    登录成功后,由于是转发,所以,浏览器链接看起来很丑,我们可以结合springMVC给它编写为重定向,通过路径main.html,重定向到dashboard.html页面。

    我们再添加一个视图控制映射,在我们的自己的MyMvcConfig中:

        registry.addViewController("/main.html").setViewName("dashboard.html");

    将 Controller 的代码改为重定向;

 return "redirect:/main.html";

测试,结果完全ok!

拦截器

    但是又发现新的问题,我们可以直接通过路径登录到后台主页,不用登录也可以实现!我们直接在地址栏填写 http://localhost:8080/main.html 也可以进入后台主页。

    这就需要写一个登录拦截器了!

    首先在刚才的controller中引入session,并且登录成功会像浏览器中存入一个session。
在这里插入图片描述
在这里插入图片描述

    然后将拦截器注册到我们的SpringMVC配置类当中!

//注册拦截器
    @Override
    public void addInterceptors(InterceptorRegistry registry) {
        //注册拦截器,及拦截请求和要剔除哪些请求!
        //我们还需要剔除静态资源文件,否则可能样式显示不出来
        registry.addInterceptor(new LoginHandlerInterceptor())
            .addPathPatterns("/**").excludePathPatterns("/index.html","/","/user/login","/css/**","/js/**","/img/**");
    }

    拓展
    我们可以通过存入的session,取到用户名,并把用户名显示到页面上
在这里插入图片描述
    运行测试!答案毋庸置疑,成功!

    这样我们无论输入什么用户名,该页面都会显示出来了!
在这里插入图片描述
在这里插入图片描述
我们的首页登录和拦截就做好了,下面实现我们把模拟的数据库内容显示在页面中

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值