From a7c9ed23a07e22b525942d989eb8a159f2a4f130 Mon Sep 17 00:00:00 2001 From: guyue <1721849008@qq.com> Date: 星期三, 30 七月 2025 14:32:48 +0800 Subject: [PATCH] 修改重复次数统计增加num --- src/main/java/com/linghu/controller/AuthController.java | 82 +++++++++++++++++++++++++++++++++------- 1 files changed, 67 insertions(+), 15 deletions(-) diff --git a/src/main/java/com/linghu/controller/AuthController.java b/src/main/java/com/linghu/controller/AuthController.java index 6ff8df4..7f86c79 100644 --- a/src/main/java/com/linghu/controller/AuthController.java +++ b/src/main/java/com/linghu/controller/AuthController.java @@ -1,15 +1,17 @@ package com.linghu.controller; -import java.util.HashMap; -import java.util.Map; +import com.fasterxml.jackson.core.JsonProcessingException; +import com.fasterxml.jackson.databind.JsonNode; +import com.fasterxml.jackson.databind.ObjectMapper; +import com.linghu.model.common.ResponseResult; +import com.linghu.model.dto.TokenRequest; import com.linghu.utils.OpenCryptUtil; import org.springframework.beans.factory.annotation.Value; import org.springframework.http.ResponseEntity; import org.springframework.web.bind.annotation.*; -import com.linghu.model.entity.User; -import com.linghu.utils.JwtUtils; + import io.swagger.annotations.Api; import io.swagger.annotations.ApiOperation; @@ -47,20 +49,70 @@ // return ResponseEntity.ok(user); // } //open-crypt解析token - @GetMapping("/parseToken") + @PostMapping("/parseToken") @ApiOperation(value = "解析token") - public ResponseEntity<?> parseToken(@RequestParam String token) { - if (token == null || "".equals(token)){ - return ResponseEntity.ok("token为空"); + public ResponseResult<?> parseToken(@RequestBody TokenRequest tokenRequest) { + String token = tokenRequest.getToken(); + if (token == null || token.isEmpty()) { + return ResponseResult.success("token为空"); } - // 解析token,获取用户信息 - OpenCryptUtil openCryptUtil = new OpenCryptUtil(); - String decrypt = openCryptUtil.decrypt(token); - System.out.println(decrypt); - System.out.println("----------------"); - // 返回用户信息 - return ResponseEntity.ok(decrypt); +// try { + // 解密token + OpenCryptUtil openCryptUtil = new OpenCryptUtil(); + String decrypt = openCryptUtil.decrypt(token); + //转换为对象 + try { + + return ResponseResult.success(decrypt); + } catch (Exception e) { + return ResponseResult.error(e.getMessage()); + } + +// // 处理可能的JSON格式问题 +// String cleanedJson = cleanJsonString(decrypt); +// +// // 使用ObjectMapper解析JSON +// ObjectMapper objectMapper = new ObjectMapper(); +// JsonNode root = objectMapper.readTree(cleanedJson); + + // 提取所需字段 +// String name = root.get("name").asText(); + + // } catch (JsonProcessingException e) { +// // 处理JSON解析异常 +// return ResponseEntity.badRequest().body("JSON解析失败: " + e.getMessage()); +// } catch (Exception e) { +// // 处理其他异常 +// return ResponseEntity.badRequest().body("解析失败: " + e.getMessage()); +// } + } + + /** + * 清理JSON字符串,处理可能的格式问题 + * @param jsonString 原始JSON字符串 + * @return 清理后的JSON字符串 + */ + private String cleanJsonString(String jsonString) { + if (jsonString == null) { + return null; + } + + // 移除字符串开头和结尾可能存在的引号 + String result = jsonString.trim(); + if (result.startsWith("\"") && result.endsWith("\"") && result.length() > 1) { + result = result.substring(1, result.length() - 1); + } + + // 处理转义的引号 + result = result.replace("\\\"", "\""); + + // 处理换行符和其他转义字符 + result = result.replace("\\n", "\n") + .replace("\\r", "\r") + .replace("\\t", "\t"); + + return result; } @GetMapping("/getToken") -- Gitblit v1.7.1