io.nerv.security.entrypoint.UrlLogoutSuccessHandler Maven / Gradle / Ivy
package io.nerv.security.entrypoint;
import cn.hutool.extra.servlet.ServletUtil;
import io.nerv.core.constant.CommonConstant;
import io.nerv.core.enums.BizCodeEnum;
import io.nerv.core.mvc.vo.Response;
import io.nerv.core.token.util.CacheTokenUtil;
import io.nerv.core.util.JsonUtil;
import io.nerv.core.util.SecurityHelper;
import io.nerv.properties.EvaConfig;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.http.MediaType;
import org.springframework.security.core.Authentication;
import org.springframework.security.web.authentication.logout.LogoutSuccessHandler;
import org.springframework.stereotype.Component;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
/**
* 自定义注销成功处理器
*/
@Component
public class UrlLogoutSuccessHandler implements LogoutSuccessHandler {
@Autowired
private JsonUtil jsonUtil;
@Autowired
private EvaConfig evaConfig;
@Autowired
private SecurityHelper securityHelper;
@Autowired
private CacheTokenUtil tokenUtil;
@Override
public void onLogoutSuccess(HttpServletRequest httpServletRequest,
HttpServletResponse httpServletResponse,
Authentication authentication) throws IOException {
var cacheToken = evaConfig.getJwt().isPersistence();
// 清空redis/caffeine中的token 刷新用户secret
if (cacheToken) {
this.tokenUtil.removeToken(securityHelper.getJwtUser().getAccount());
}
// 清除cookie
ServletUtil.addCookie(httpServletResponse,
CommonConstant.ACCESS_TOKEN_KEY,
null,
0,
"/",
evaConfig.getCookie().getDomain());
ServletUtil.addCookie(httpServletResponse,
CommonConstant.REFRESH_TOKEN_KEY,
null,
0,
"/",
evaConfig.getCookie().getDomain());
ServletUtil.addCookie(httpServletResponse,
CommonConstant.USER_KEY,
null,
0,
"/",
evaConfig.getCookie().getDomain());
httpServletResponse.setCharacterEncoding("UTF-8");
httpServletResponse.setContentType(MediaType.APPLICATION_JSON_VALUE);
httpServletResponse.setStatus(HttpServletResponse.SC_OK);
httpServletResponse.getWriter().write(jsonUtil.toJSONString(new Response().failure(BizCodeEnum.LOGINOUT_SUCCESS)));
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy