package com.xiaoniu.auth.controller; import com.xiaoniu.auth.form.LoginBody; import com.xiaoniu.auth.form.RegisterBody; import com.xiaoniu.auth.service.SysLoginService; import com.xiaoniu.common.core.domain.R; import com.xiaoniu.common.core.utils.JwtUtils; import com.xiaoniu.common.core.utils.StringUtils; import com.xiaoniu.common.security.auth.AuthUtil; import com.xiaoniu.common.security.service.TokenService; import com.xiaoniu.common.security.utils.SecurityUtils; import com.xiaoniu.system.api.model.LoginUser; import io.swagger.v3.oas.annotations.tags.Tag; import jakarta.servlet.http.HttpServletRequest; import lombok.AllArgsConstructor; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.*; /** * token 控制 * * @author xiaoniu */ @RestController @AllArgsConstructor @RequestMapping @Tag(name = "用户登录管理", description = "用户登录管理接口") public class TokenController { private final TokenService tokenService; private final SysLoginService sysLoginService; @PostMapping("/login") public R login(@RequestBody LoginBody form) { // 用户登录 LoginUser userInfo = sysLoginService.login(form.getUsername(), form.getPassword()); // 获取登录token return R.ok(tokenService.createToken(userInfo)); } @DeleteMapping("/logout") public R logout(HttpServletRequest request) { String token = SecurityUtils.getToken(request); if (StringUtils.isNotEmpty(token)) { String username = JwtUtils.getUserName(token); // 删除用户缓存记录 AuthUtil.logoutByToken(token); // 记录用户退出日志 sysLoginService.logout(username); } return R.ok(); } @PostMapping("/refresh") public R refresh(HttpServletRequest request) { LoginUser loginUser = tokenService.getLoginUser(request); if (StringUtils.isNotNull(loginUser)) { // 刷新令牌有效期 tokenService.refreshToken(loginUser); return R.ok(); } return R.ok(); } @PostMapping("/register") public R register(@RequestBody RegisterBody registerBody) { // 用户注册 sysLoginService.register(registerBody.getUsername(), registerBody.getPassword()); return R.ok(); } }