From 580d70b15ae47bc180a0b579af8c47c506eefac6 Mon Sep 17 00:00:00 2001 From: huliguo <2023611923@qq.com> Date: 星期五, 11 七月 2025 20:13:38 +0800 Subject: [PATCH] 修改 --- src/main/java/com/linghu/controller/AuthController.java | 68 +++++++++++++++++++++------------- 1 files changed, 42 insertions(+), 26 deletions(-) diff --git a/src/main/java/com/linghu/controller/AuthController.java b/src/main/java/com/linghu/controller/AuthController.java index aa7f072..6d7e0c4 100644 --- a/src/main/java/com/linghu/controller/AuthController.java +++ b/src/main/java/com/linghu/controller/AuthController.java @@ -2,7 +2,13 @@ import java.util.HashMap; import java.util.Map; +import java.util.regex.Matcher; +import java.util.regex.Pattern; +import com.alibaba.fastjson.JSONObject; +import com.fasterxml.jackson.core.JsonProcessingException; +import com.fasterxml.jackson.databind.JsonNode; +import com.fasterxml.jackson.databind.ObjectMapper; import com.linghu.utils.OpenCryptUtil; import org.springframework.beans.factory.annotation.Value; import org.springframework.http.ResponseEntity; @@ -21,35 +27,35 @@ @Value("${jwt.secret}") private String secretKey; - @PostMapping("/login") - @ApiOperation(value = "外部登录") - public ResponseEntity<?> externalLogin( - @RequestBody User user) { - - // 生成JWT令牌 - JwtUtils jwtUtils = new JwtUtils(secretKey, 3600); - String token = jwtUtils.generateToken(user); - - Map<String, String> response = new HashMap<>(); - response.put("token", token); - // 返回JWT令牌 - return ResponseEntity.ok(response); - } +// @PostMapping("/login") +// @ApiOperation(value = "外部登录") +// public ResponseEntity<?> externalLogin( +// @RequestBody User user) { +// +// // 生成JWT令牌 +// JwtUtils jwtUtils = new JwtUtils(secretKey, 3600); +// String token = jwtUtils.generateToken(user); +// +// Map<String, String> response = new HashMap<>(); +// response.put("token", token); +// // 返回JWT令牌 +// return ResponseEntity.ok(response); +// } // 获取用户信息 - @PostMapping("/getUserInfo") - @ApiOperation(value = "获取用户信息") - public ResponseEntity<?> getUserInfo(@RequestParam String token) { - // 解析JWT令牌,获取用户信息 - JwtUtils jwtUtils = new JwtUtils(secretKey, 3600); - User user = jwtUtils.parseToken(token); - // 返回用户信息 - return ResponseEntity.ok(user); - } +// @PostMapping("/getUserInfo") +// @ApiOperation(value = "获取用户信息") +// public ResponseEntity<?> getUserInfo(@RequestParam String token) { +// // 解析JWT令牌,获取用户信息 +// JwtUtils jwtUtils = new JwtUtils(secretKey, 3600); +// User user = jwtUtils.parseToken(token); +// // 返回用户信息 +// return ResponseEntity.ok(user); +// } //open-crypt解析token @GetMapping("/parseToken") @ApiOperation(value = "解析token") - public ResponseEntity<?> parseToken(@RequestParam String token) { + public ResponseEntity<?> parseToken(@RequestParam String token) throws JsonProcessingException { if (token == null || "".equals(token)){ return ResponseEntity.ok("token为空"); } @@ -58,14 +64,24 @@ String decrypt = openCryptUtil.decrypt(token); System.out.println(decrypt); System.out.println("----------------"); + // 1. 去除外层多余的引号 + String jsonStr = decrypt.replaceAll("^\"|\"$", ""); + // 处理后:{"name":"ceshi"}(但实际可能仍包含转义字符) + + // 2. 处理剩余的转义字符(将 \" 转换为 ") + jsonStr = jsonStr.replace("\\\"", "\""); + + // 3. 解析 JSON + ObjectMapper objectMapper = new ObjectMapper(); + String name = objectMapper.readTree(jsonStr).get("name").asText(); // 返回用户信息 - return ResponseEntity.ok(decrypt); + return ResponseEntity.ok(name); } @GetMapping("/getToken") @ApiOperation(value = "获取token") - public ResponseEntity<?> getToken(@RequestBody User user) { + public ResponseEntity<?> getToken( String user) { // 创建用户对 // 创建JwtUtils对象,并生成JWT令牌 -- Gitblit v1.7.1