springboot登录拦截器的具体例子
时间: 2023-07-03 10:19:26 浏览: 44
SpringBoot拦截器实现登录拦截的方法示例
好的,下面是一个简单的Spring Boot登录拦截器的例子:
首先,我们需要创建一个拦截器类来检查用户是否已登录:
```java
public class LoginInterceptor implements HandlerInterceptor {
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
HttpSession session = request.getSession();
Object user = session.getAttribute("user");
if (user == null) {
response.sendRedirect("/login");
return false;
}
return true;
}
}
```
在上面的代码中,我们实现了`HandlerInterceptor`接口,并覆盖了其中的`preHandle()`方法,在该方法中,我们从当前会话中获取用户对象,如果用户对象为空,则重定向到登录页面。
接下来,我们需要在Spring Boot应用程序中注册拦截器。可以通过在配置类中添加`@Configuration`和`@EnableWebMvc`注解来实现:
```java
@Configuration
@EnableWebMvc
public class WebMvcConfig implements WebMvcConfigurer {
@Autowired
private LoginInterceptor loginInterceptor;
@Override
public void addInterceptors(InterceptorRegistry registry) {
registry.addInterceptor(loginInterceptor).addPathPatterns("/**").excludePathPatterns("/login", "/register");
}
}
```
在上面的代码中,我们首先使用`@Autowired`注解注入了我们之前定义的`LoginInterceptor`对象,然后通过`addInterceptors()`方法注册了拦截器,并指定了需要拦截的路径和排除的路径。
最后,我们还需要在`Controller`方法中添加`@RequestMapping`注解来指定登录页面和处理登录请求的方法:
```java
@Controller
public class LoginController {
@GetMapping("/login")
public String login() {
return "login";
}
@PostMapping("/login")
public String doLogin(@RequestParam String username, @RequestParam String password, HttpSession session) {
// 校验用户名和密码,并将用户对象保存到会话中
session.setAttribute("user", user);
return "redirect:/home";
}
}
```
在上面的代码中,我们首先使用`@GetMapping`注解指定了登录页面的访问路径,然后使用`@PostMapping`注解指定了处理登录请求的方法,该方法会校验用户名和密码,并将用户对象保存到会话中。如果验证通过,则重定向到主页。
阅读全文