From 347909bae241fff128b628ea6d12992d7e5b4b10 Mon Sep 17 00:00:00 2001 From: xin <1099200748@qq.com> Date: Fri, 30 May 2025 18:35:43 +0800 Subject: [PATCH] 响应信息主体 --- oying-system/src/main/java/com/oying/modules/security/rest/AuthController.java | 36 +++++++++++++++++++++++++++--------- 1 files changed, 27 insertions(+), 9 deletions(-) diff --git a/oying-system/src/main/java/com/oying/modules/security/rest/AuthController.java b/oying-system/src/main/java/com/oying/modules/security/rest/AuthController.java index 34ad8ad..da9d9b8 100644 --- a/oying-system/src/main/java/com/oying/modules/security/rest/AuthController.java +++ b/oying-system/src/main/java/com/oying/modules/security/rest/AuthController.java @@ -10,6 +10,7 @@ import com.oying.modules.security.service.UserDetailsServiceImpl; import com.oying.modules.security.service.dto.AuthUserDto; import com.oying.modules.security.service.dto.JwtUserDto; +import com.oying.utils.*; import com.wf.captcha.base.Captcha; import io.swagger.annotations.Api; import io.swagger.annotations.ApiOperation; @@ -21,10 +22,6 @@ import com.oying.annotation.rest.AnonymousPostMapping; import com.oying.config.properties.RsaProperties; import com.oying.exception.BadRequestException; -import com.oying.utils.RsaUtils; -import com.oying.utils.RedisUtils; -import com.oying.utils.SecurityUtils; -import com.oying.utils.StringUtils; import org.springframework.http.HttpStatus; import org.springframework.http.ResponseEntity; import org.springframework.security.authentication.UsernamePasswordAuthenticationToken; @@ -34,6 +31,7 @@ import org.springframework.security.crypto.password.PasswordEncoder; import org.springframework.validation.annotation.Validated; import org.springframework.web.bind.annotation.*; + import javax.servlet.http.HttpServletRequest; import java.util.HashMap; import java.util.Map; @@ -98,14 +96,34 @@ // 保存在线信息 onlineUserService.save(jwtUser, token, request); // 返回登录信息 - return ResponseEntity.ok(authInfo); + return ResponseEntity.ok(R.success(authInfo)); + } + + @ApiOperation("临时授权") + @AnonymousGetMapping(value = "/token") + public ResponseEntity<Object> loginTest(@RequestParam String username, HttpServletRequest request) { + // 生成令牌与第三方系统获取令牌方式 + JwtUserDto jwtUser = userDetailsService.loadUserByUsername(username); + Authentication authentication = new UsernamePasswordAuthenticationToken(jwtUser, null, jwtUser.getAuthorities()); + SecurityContextHolder.getContext().setAuthentication(authentication); + // 生成令牌 + String token = tokenProvider.createToken(jwtUser); + // 返回 token 与 用户信息 + Map<String, Object> authInfo = new HashMap<String, Object>(2) {{ + put("token", properties.getTokenStartWith() + token); + put("user", jwtUser); + }}; + // 保存在线信息 + onlineUserService.save(jwtUser, token, request); + // 返回登录信息 + return ResponseEntity.ok(R.success(authInfo)); } @ApiOperation("获取用户信息") @GetMapping(value = "/info") - public ResponseEntity<UserDetails> getUserInfo() { + public ResponseEntity<Object> getUserInfo() { JwtUserDto jwtUser = (JwtUserDto) SecurityUtils.getCurrentUser(); - return ResponseEntity.ok(jwtUser); + return ResponseEntity.ok(R.success(jwtUser)); } @ApiOperation("获取验证码") @@ -126,7 +144,7 @@ put("img", captcha.toBase64()); put("uuid", uuid); }}; - return ResponseEntity.ok(imgResult); + return ResponseEntity.ok(R.success(imgResult)); } @ApiOperation("退出登录") @@ -134,6 +152,6 @@ public ResponseEntity<Object> logout(HttpServletRequest request) { String token = tokenProvider.getToken(request); onlineUserService.logout(token); - return new ResponseEntity<>(HttpStatus.OK); + return new ResponseEntity<>(R.success(), HttpStatus.OK); } } -- Gitblit v1.9.3