检查登录状态(八)
防止在用户为登录时,可以访问登录后的功能。比如未登录就通过url访问账号设置页面。
- 使用拦截器
- 在方法前标注自定义注解
- 拦截所有请求,只处理带有该注解的方法
- 自定义注解
- 常用元注解:
@Target
(描述该注解可以作用的目标类型)
@Retention
(描述该注解被保留的时间)
@Document
(描述该注解是否可以生成到文档里)
@Inherited
(其标记的注解允许被继承,接口实现除外) - 如何读取注解
Method.getDeclaredAnnotations()
Method.getAnnotations(Class<T> annotationClass)
- 常用元注解:
一、定义注解
使方法登录后有效。
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
public @interface LoginRequired {
//定义在方法上
//运行时有效
}
二、设置注解
比如访问账号设置页面、上传头像方法
@LoginRequired
@GetMapping(path = "/setting")
public String getSettingPage() {
//...
}
//上传头像
@LoginRequired
@PostMapping(path = "/upload")
public String uploadHeader(MultipartFile headerImage, Model model) {
//...
}
三、设置拦截器
import com.nowcoder.community.annotation.LoginRequired;
import com.nowcoder.community.utils.HostHolder;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
import org.springframework.web.method.HandlerMethod;
import org.springframework.web.servlet.HandlerInterceptor;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.lang.reflect.Method;
@Component
public class LoginRequiredInterceptor implements HandlerInterceptor {
@Autowired
private HostHolder hostHolder;
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
//判断拦截类型是不是方法
if (handler instanceof HandlerMethod) {
HandlerMethod handlerMethod = (HandlerMethod) handler;
Method method = handlerMethod.getMethod();
LoginRequired loginRequired = method.getAnnotation(LoginRequired.class);
//判断是否有LoginRequired注解以及用户是否登录
if (loginRequired != null && hostHolder.getUser() == null) {
//重定向到登录页面
response.sendRedirect(request.getContextPath() + "/login");
return false;
}
}
return true;
}
}
配置拦截器,不拦截静态资源。
@Configuration
public class WebMvcConfig implements WebMvcConfigurer {
//...
@Autowired
private LoginRequiredInterceptor loginRequiredInterceptor;
@Override
public void addInterceptors(InterceptorRegistry registry) {
//...
registry.addInterceptor(loginRequiredInterceptor)
.excludePathPatterns("/**/*.css", "/**/*.js", "/**/*.png", "/**/*.jpg", "/**/*.jpeg");
}
}
未登录时,输入账号设置页面的url
直接返回登录页面
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)