From 1d22a73ebd5cb8bd420e8ab55e18d5bd19bfdc1e Mon Sep 17 00:00:00 2001 From: guyue <1721849008@qq.com> Date: 星期三, 23 七月 2025 10:22:34 +0800 Subject: [PATCH] 更新判断新平台 --- src/main/java/com/linghu/controller/CollectController.java | 60 ++++++++++++++++++++++++++---------------------------------- 1 files changed, 26 insertions(+), 34 deletions(-) diff --git a/src/main/java/com/linghu/controller/CollectController.java b/src/main/java/com/linghu/controller/CollectController.java index 61f9f54..7b5bc54 100644 --- a/src/main/java/com/linghu/controller/CollectController.java +++ b/src/main/java/com/linghu/controller/CollectController.java @@ -589,7 +589,8 @@ */ private Platform getOrCreatePlatform(String domain,String platformName) { // 1. 先尝试查询已存在的平台 - Platform platform = platformService.getPlatformByDomain(domain,platformName); + + Platform platform = platformService.getPlatformByDomain(domain); if (platform != null) { return platform; } @@ -624,7 +625,7 @@ } catch (DuplicateKeyException e) { // 3. 若捕获到重复键异常,说明并发创建了,重新查询即可(此时数据库中已存在该平台) log.warn("平台domain={}已存在,无需重复创建", domain, e); - return platformService.getPlatformByDomain(domain,platformName); // 重新查询,一定能获取到 + return platformService.getPlatformByDomain(domain); // 重新查询,一定能获取到 } catch (Exception e) { // 处理其他异常(如数据库连接失败等) log.error("创建平台失败,domain={}", domain, e); @@ -724,11 +725,27 @@ List<Reference> allReferences = new ArrayList<>(); List<Reference> resultList = new ArrayList<>(); - // 4. 新增:统计所有提问词的结果状态 - boolean allEmptyReferences = true; // 所有提问词引用数据为空 - boolean allSystemBusy = true; // 所有提问词系统繁忙 // 遍历结果 for (UserResult userResult : result.getResults()) { + //更新账号状态 + if ( "failed".equals(userResult.getStatus())){ + if (userResult.getError().contains("登录失败")){ + LambdaUpdateWrapper<User> userWrapper = new LambdaUpdateWrapper<>(); + userWrapper.eq(User::getUser_email, userResult.getUser_email()); + userWrapper.set(User::getStatus, "无法登录"); + userService.update(userWrapper); + //更新所有提问词的状态 + questionService.update(new LambdaUpdateWrapper<Question>().eq(Question::getKeyword_id, keyword.getKeyword_id()) + .set(Question::getStatus, "failed") + .set(Question::getError, "账户登录失败")); + + }else if (userResult.getError().contains("信息错误")){ + LambdaUpdateWrapper<User> userWrapper = new LambdaUpdateWrapper<>(); + userWrapper.eq(User::getUser_email, userResult.getUser_email()); + userWrapper.set(User::getStatus, "信息错误"); + userService.update(userWrapper); + } + } for (QuestionResult questionResult : userResult.getQuestions_results()) { try { Question question = questionMap.get(questionResult.getQuestion()); @@ -765,15 +782,13 @@ String finalStatus = determineFinalStatus(allResults); if ("success".equals(finalStatus)){ question.setStatus("success"); + question.setError(""); }else if ("no_results".equals(finalStatus)){ - question.setStatus("failed"); + question.setStatus("success"); question.setError("采集结果无引用数据"); }else if ("busyness".equals(finalStatus)){ question.setStatus("failed"); question.setError("DeepSeek繁忙,请稍后尝试"); - }else if ("failed".equals(finalStatus)){ - question.setStatus("failed"); - question.setError("所有账号登录失败"); } // 更新问题对象 @@ -876,25 +891,7 @@ System.out.println("处理问题结果失败: " + e.getMessage()); } } - //更新账号状态 - if ( "failed".equals(userResult.getStatus())){ - if (userResult.getError().contains("登录失败")){ - LambdaUpdateWrapper<User> userWrapper = new LambdaUpdateWrapper<>(); - userWrapper.eq(User::getUser_email, userResult.getUser_email()); - userWrapper.set(User::getStatus, "无法登录"); - userService.update(userWrapper); - //更新所有提问词的状态 - questionService.update(new LambdaUpdateWrapper<Question>().eq(Question::getKeyword_id, keyword.getKeyword_id()) - .set(Question::getStatus, "failed") - .set(Question::getError, "账户登录失败")); - }else if (userResult.getError().contains("信息错误")){ - LambdaUpdateWrapper<User> userWrapper = new LambdaUpdateWrapper<>(); - userWrapper.eq(User::getUser_email, userResult.getUser_email()); - userWrapper.set(User::getStatus, "信息错误"); - userService.update(userWrapper); - } - } } @@ -921,7 +918,6 @@ int totalCount = results.size(); int emptyResponseCount = 0; int systemBusyCount = 0; - int failedCount = 0; for (QuestionResultList result : results) { // 判断回答是否为空 @@ -933,9 +929,7 @@ if ("success".equals(result.getStatus()) && (result.getResponse().isEmpty()|| result.getResponse().contains("WebDriver连接中断") || result.getResponse().contains("响应超时"))) { systemBusyCount++; } - if ("failed".equals(result.getStatus()) && result.getError().contains("登录失败")){ - failedCount++; - } + } // 全返回系统繁忙 @@ -946,9 +940,7 @@ if (emptyResponseCount == totalCount) { return "no_results"; } - if (failedCount == totalCount) { - return "failed"; - } + // 系统繁忙比例超过阈值(可配置,这里设为70%) // double busyRate = (double) systemBusyCount / totalCount; -- Gitblit v1.7.1