今天做一条翻身的咸鱼 2019-11-06 17:33 采纳率: 0%
浏览 373
已采纳

项目中自定义的拦截器在没有接口请求的时候为什么一直在执行

在我看来,拦截器应该是接收到一个请求后才会执行,但是为什么我在项目中自定义的这个拦截器在没有任何接口去请求的时候也一直在执行啊?求大神指教呀~
下面是我的代码和后台打印的日志

package com.test.user.interceptor

import com.test.common.ErrMsg
import com.test.common.Result
import com.test.common.Sessions
import com.test.common.constant.IbErrMsg
import org.slf4j.LoggerFactory
import org.springframework.web.servlet.HandlerInterceptor
import javax.servlet.http.HttpServletRequest
import javax.servlet.http.HttpServletResponse
import javax.validation.constraints.NotNull

class LoginInterceptor : HandlerInterceptor {

  private val logger = LoggerFactory.getLogger(LoginInterceptor::class.java)

  override fun preHandle(@NotNull request: HttpServletRequest,
                         @NotNull response: HttpServletResponse,
                         @NotNull handler: Any): Boolean {
    val requestUri = request.requestURI
    if (requestUri == "/open/user/pwdLogin_v2") {
      return true
    }
    //登录鉴定
    val session = request.session
    if (session == null) {
      logger.warn("session为空...")
      err(response, IbErrMsg.SESSION_ID_ERR)
      return false
    }
    val userDetails = Sessions.getUserDetails(session)
    if (userDetails == null) {
      logger.warn("session中用户信息为空!")
      err(response, IbErrMsg.NOT_LOGIN_IN)
      return false
    }
    return true
  }

  private fun err(response: HttpServletResponse, msg: ErrMsg) {
    response.contentType = "application/json;charset=UTF-8"
    val err: Result<Unit> = Result.error(msg)
    val writer = response.writer
    writer.println(err)
  }

}

图片说明

  • 写回答

1条回答 默认 最新

  • 毕小宝 博客专家认证 2019-11-06 17:54
    关注

    你可以打印一下 request 请求的信息中的 URL ,看看是什么请求,应该是由请求触发的。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥50 gki vendor hook
  • ¥15 centos7中sudo命令无法使用
  • ¥15 灰狼算法和蚁群算法如何结合
  • ¥15 这是一个利用ESP32自带按键和LED控制的录像代码,编译过程出现问题,请解决并且指出错误,指导如何处理 ,协助完成代码并上传代码
  • ¥20 stm32f103,hal库 hal_usart_receive函数接收不到数据。
  • ¥20 求结果和代码,sas利用OPTEX程序和D-efficiency生成正交集
  • ¥50 adb连接不到手机是怎么回事?
  • ¥20 抓取数据时发生错误: get_mooncake_data() missing 1 required positional argument: 'driver'的问题,怎么改出正确的爬虫代码?
  • ¥15 vs2022无法联网
  • ¥15 TCP的客户端和服务器的互联