100字范文,内容丰富有趣,生活中的好帮手!
100字范文 > SpringMVC拦截器-用户登录权限控制

SpringMVC拦截器-用户登录权限控制

时间:2019-01-08 03:23:05

相关推荐

SpringMVC拦截器-用户登录权限控制

06-SpringMVC拦截器-用户登录权限控制分析(理解)

需求概述:用户没有登录的情况下,不能对后台菜单进行访问操作,点击菜单跳转到登录页面,只有用户登录成功后才能进行后台功能的操作

07-SpringMVC拦截器-用户登录权限控制代码实现1(应用)

判断用户是否登录 本质:判断session中有没有user,如果没有登陆则先去登陆,如果已经登陆则直接放行访问目标资源

先编写拦截器如下:

public class PrivilegeInterceptor implements HandlerInterceptor {public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws IOException {//逻辑:判断用户是否登录 本质:判断session中有没有userHttpSession session = request.getSession();User user = (User) session.getAttribute("user");if(user==null){//没有登录response.sendRedirect(request.getContextPath()+"/login.jsp");return false;}//放行 访问目标资源return true;}}

然后配置该拦截器:找到项目案例的spring-mvc.xml,添加如下配置:

<!--配置权限拦截器--><mvc:interceptors><mvc:interceptor><!--配置对哪些资源执行拦截操作--><mvc:mapping path="/**"/><bean class="com.itheima.interceptor.PrivilegeInterceptor"/></mvc:interceptor></mvc:interceptors>

08-SpringMVC拦截器-用户登录权限控制代码实现2(应用)

在登陆页面输入用户名密码,点击登陆,通过用户名密码进行查询,如果登陆成功,则将用户信息实体存入session,然后跳转到首页,如果登陆失败则继续回到登陆页面

在UserController中编写登陆逻辑

@RequestMapping("/login")public String login(String username,String password,HttpSession session){User user = userService.login(username,password);if(user!=null){//登录成功 将user存储到sessionsession.setAttribute("user",user);return "redirect:/index.jsp";}return "redirect:/login.jsp";}

service层代码如下:

//service层public User login(String username, String password) {User user = userDao.findByUsernameAndPassword(username,password);return user;}

dao层代码如下:

//dao层public User findByUsernameAndPassword(String username, String password) throws EmptyResultDataAccessException{User user = jdbcTemplate.queryForObject("select * from sys_user where username=? and password=?", new BeanPropertyRowMapper<User>(User.class), username, password);return user;}

此时仍然登陆不上,因为我们需要将登陆请求url让拦截器放行,添加资源排除的配置

<!--配置权限拦截器--><mvc:interceptors><mvc:interceptor><!--配置对哪些资源执行拦截操作--><mvc:mapping path="/**"/><!--配置哪些资源排除拦截操作--><mvc:exclude-mapping path="/user/login"/><bean class="com.itheima.interceptor.PrivilegeInterceptor"/></mvc:interceptor></mvc:interceptors>

09-SpringMVC拦截器-用户登录权限控制代码实现3(应用)

JdbcTemplate.queryForObject对象如果查询不到数据会抛异常,导致程序无法达到预期效果,如何来解决该问题?

在业务层处理来自dao层的异常,如果出现异常service层返回null,而不是将异常抛给controller

因此改造登陆的业务层代码,添加异常的控制

public User login(String username, String password) {try {User user = userDao.findByUsernameAndPassword(username,password);return user;}catch (EmptyResultDataAccessException e){return null;}}

实现截图如下

在这里共享一下例子代码,需要的请去下载/LCreator/spring_learning

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。