From 8d602fe2a474ee3baae4447c7f07d027b25bedfe Mon Sep 17 00:00:00 2001
From: guyue <1721849008@qq.com>
Date: 星期四, 17 七月 2025 21:30:02 +0800
Subject: [PATCH] 修改token解析

---
 src/main/java/com/linghu/controller/AuthController.java |   50 +++++++++++++++++++++++++++++++-------------------
 1 files changed, 31 insertions(+), 19 deletions(-)

diff --git a/src/main/java/com/linghu/controller/AuthController.java b/src/main/java/com/linghu/controller/AuthController.java
index 57547b5..06e9f4a 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;
@@ -49,29 +55,35 @@
     //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为空");
         }
-        // 解析token,获取用户信息
-        OpenCryptUtil openCryptUtil = new OpenCryptUtil();
-        String decrypt = openCryptUtil.decrypt(token);
-        System.out.println(decrypt);
-        System.out.println("----------------");
+        try {
+            OpenCryptUtil openCryptUtil = new OpenCryptUtil();
+            String decrypt = openCryptUtil.decrypt(token);
 
-        // 返回用户信息
-        return ResponseEntity.ok(decrypt);
+            // 使用 ObjectMapper 反序列化,避免手动处理转义字符
+            ObjectMapper objectMapper = new ObjectMapper();
+            JsonNode root = objectMapper.readTree(decrypt);
+            String name = root.get("name").asText();
+
+            return ResponseEntity.ok(name);
+        } catch (Exception e) {
+            // 捕获所有异常,避免500错误
+            return ResponseEntity.badRequest().body("解析失败: " + e.getMessage());
+        }
     }
 
-//    @GetMapping("/getToken")
-//    @ApiOperation(value = "获取token")
-//    public ResponseEntity<?> getToken(@RequestBody User user) {
-//        // 创建用户对
-//
-//        // 创建JwtUtils对象,并生成JWT令牌
-//        OpenCryptUtil openCryptUtil = new OpenCryptUtil();
-//        String decrypt = openCryptUtil.encrypt(user);
-//        // 返回JWT令牌
-//        return ResponseEntity.ok(decrypt);
-//    }
+    @GetMapping("/getToken")
+    @ApiOperation(value = "获取token")
+    public ResponseEntity<?> getToken( String user) {
+        // 创建用户对
+
+        // 创建JwtUtils对象,并生成JWT令牌
+        OpenCryptUtil openCryptUtil = new OpenCryptUtil();
+        String decrypt = openCryptUtil.encrypt(user);
+        // 返回JWT令牌
+        return ResponseEntity.ok(decrypt);
+    }
 }
\ No newline at end of file

--
Gitblit v1.7.1