guyue
1 天以前 286cc1963d6d5a26f26c78d542974691b80a86f7
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令牌