public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { // String token = TokenHelper.getFromReq(request); String token = request.getHeader(Authentication.TOKEN_NAME); if (StringUtils.isEmpty(token)) { // mute for OPTIONS if (!request.getMethod().equalsIgnoreCase(HttpMethod.OPTIONS.name())) { // need log return true; } return false; } UserContext userContext = Authentication.verify(token); if (userContext == null) { log.error(""); return false; } UserContextHolder.set(userContext); return true; } 这段代码干什么的
时间: 2024-02-14 20:27:45 浏览: 150
JavaScript引用类型之基本包装类型实例分析【Boolean、Number和String】
这段代码是一个拦截器(Interceptor)中的方法,用于在请求处理之前进行预处理。具体功能如下:
1. 获取请求中的 token 值。在这段代码中,使用 `request.getHeader(Authentication.TOKEN_NAME)` 方法从请求头中获取 token。
2. 检查 token 是否为空,如果为空,则判断请求方法是否为 OPTIONS。如果是 OPTIONS 请求,则直接返回 false,表示允许跨域请求的预检请求通过;如果不是 OPTIONS 请求,则需要记录日志,并返回 true。
3. 如果 token 不为空,则调用 `Authentication.verify(token)` 方法进行验证。如果验证成功,返回一个包含用户上下文信息的 `UserContext` 对象;如果验证失败,则记录错误日志,并返回 false。
4. 如果验证成功,将用户上下文信息存储到 `UserContextHolder` 中,以便后续代码可以获取到用户上下文信息。
5. 最后,返回 true 表示请求预处理通过,可以继续处理该请求。
阅读全文