From 44e8988174ba750026fe3a5fcfade198d959766c Mon Sep 17 00:00:00 2001
From: Administrator <15274802129@163.com>
Date: Wed, 25 Feb 2026 11:01:14 +0800
Subject: [PATCH] feat(ai): 添加产品翻译功能

---
 src/main/java/cc/mrbird/febs/ai/service/AiProductService.java                |    3 +
 src/main/java/cc/mrbird/febs/ai/controller/product/ApiProductController.java |    8 ++++
 src/main/java/cc/mrbird/febs/ai/req/product/ApiTranslateDto.java             |   20 ++++++++++
 src/main/java/cc/mrbird/febs/ai/service/impl/AiProductServiceImpl.java       |   54 +++++++++++++++++++++++++--
 4 files changed, 81 insertions(+), 4 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/ai/controller/product/ApiProductController.java b/src/main/java/cc/mrbird/febs/ai/controller/product/ApiProductController.java
index c0d8996..3448d6b 100644
--- a/src/main/java/cc/mrbird/febs/ai/controller/product/ApiProductController.java
+++ b/src/main/java/cc/mrbird/febs/ai/controller/product/ApiProductController.java
@@ -2,6 +2,7 @@
 
 import cc.mrbird.febs.ai.req.product.ApiProductInfoDto;
 import cc.mrbird.febs.ai.req.product.ApiProductPageDto;
+import cc.mrbird.febs.ai.req.product.ApiTranslateDto;
 import cc.mrbird.febs.ai.res.product.ApiProductInfoVo;
 import cc.mrbird.febs.ai.res.product.ApiProductVo;
 import cc.mrbird.febs.ai.res.productPoint.ApiProductPointVo;
@@ -62,4 +63,11 @@
         return aiProductService.pointInfoList(dto);
     }
 
+    @ApiOperation(value = "翻译", notes = "翻译")
+    @PostMapping(value = "/translate")
+    public FebsResponse translate(@RequestBody @Validated ApiTranslateDto dto) {
+
+        return aiProductService.translate(dto);
+    }
+
 }
diff --git a/src/main/java/cc/mrbird/febs/ai/req/product/ApiTranslateDto.java b/src/main/java/cc/mrbird/febs/ai/req/product/ApiTranslateDto.java
new file mode 100644
index 0000000..04d6f22
--- /dev/null
+++ b/src/main/java/cc/mrbird/febs/ai/req/product/ApiTranslateDto.java
@@ -0,0 +1,20 @@
+package cc.mrbird.febs.ai.req.product;
+
+import io.swagger.annotations.ApiModel;
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+
+@Data
+@ApiModel(value = "ApiTranslateDto", description = "参数")
+public class ApiTranslateDto {
+
+
+    @ApiModelProperty(value = "内容", example = "123")
+    private String content;
+
+    @ApiModelProperty(value = "当前语种", example = "auto")
+    private String sourceLang;
+
+    @ApiModelProperty(value = "目标语种", example = "English")
+    private String targetLang;
+}
diff --git a/src/main/java/cc/mrbird/febs/ai/service/AiProductService.java b/src/main/java/cc/mrbird/febs/ai/service/AiProductService.java
index 3801473..0d8158b 100644
--- a/src/main/java/cc/mrbird/febs/ai/service/AiProductService.java
+++ b/src/main/java/cc/mrbird/febs/ai/service/AiProductService.java
@@ -3,6 +3,7 @@
 import cc.mrbird.febs.ai.entity.AiProduct;
 import cc.mrbird.febs.ai.req.product.ApiProductInfoDto;
 import cc.mrbird.febs.ai.req.product.ApiProductPageDto;
+import cc.mrbird.febs.ai.req.product.ApiTranslateDto;
 import cc.mrbird.febs.ai.req.productCategory.ApiProductCategoryPageDto;
 import cc.mrbird.febs.ai.res.product.ApiProductVo;
 import cc.mrbird.febs.ai.res.productCategory.ApiProductCategoryVo;
@@ -31,4 +32,6 @@
     FebsResponse pointInfoList(ApiProductInfoDto dto);
 
     List<AiProduct> getProductListByQuery(LambdaQueryWrapper<AiProduct> productQuery);
+
+    FebsResponse translate(ApiTranslateDto dto);
 }
diff --git a/src/main/java/cc/mrbird/febs/ai/service/impl/AiProductServiceImpl.java b/src/main/java/cc/mrbird/febs/ai/service/impl/AiProductServiceImpl.java
index 63f5657..5514db6 100644
--- a/src/main/java/cc/mrbird/febs/ai/service/impl/AiProductServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/ai/service/impl/AiProductServiceImpl.java
@@ -7,6 +7,7 @@
 import cc.mrbird.febs.ai.mapper.AiProductMapper;
 import cc.mrbird.febs.ai.req.product.ApiProductInfoDto;
 import cc.mrbird.febs.ai.req.product.ApiProductPageDto;
+import cc.mrbird.febs.ai.req.product.ApiTranslateDto;
 import cc.mrbird.febs.ai.res.product.ApiProductInfoVo;
 import cc.mrbird.febs.ai.res.product.ApiProductVo;
 import cc.mrbird.febs.ai.res.productPoint.ApiProductPointVo;
@@ -16,6 +17,14 @@
 import cn.hutool.core.collection.CollUtil;
 import cn.hutool.core.util.ObjectUtil;
 import cn.hutool.core.util.StrUtil;
+import com.alibaba.dashscope.aigc.generation.Generation;
+import com.alibaba.dashscope.aigc.generation.GenerationParam;
+import com.alibaba.dashscope.aigc.generation.GenerationResult;
+import com.alibaba.dashscope.aigc.generation.TranslationOptions;
+import com.alibaba.dashscope.common.Message;
+import com.alibaba.dashscope.common.Role;
+import com.alibaba.dashscope.exception.InputRequiredException;
+import com.alibaba.dashscope.exception.NoApiKeyException;
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
@@ -23,9 +32,7 @@
 import lombok.extern.slf4j.Slf4j;
 import org.springframework.stereotype.Service;
 
-import java.util.List;
-import java.util.Map;
-import java.util.Set;
+import java.util.*;
 import java.util.stream.Collectors;
 
 /**
@@ -45,7 +52,6 @@
     private final AiProductPointService aiProductPointService;
     private final AiProductDependencyService aiProductDependencyService;
     private final AiMemberProductUnlockService aiMemberProductUnlockService;
-
 
     @Override
     public AiProduct getById(String id) {
@@ -140,4 +146,44 @@
     public List<AiProduct> getProductListByQuery(LambdaQueryWrapper<AiProduct> productQuery) {
         return aiProductMapper.selectList(productQuery);
     }
+
+    @Override
+    public FebsResponse translate(ApiTranslateDto dto) {
+        long startTime = System.currentTimeMillis();
+        
+        HashMap<Object, Object> map = new HashMap<>();
+        Generation gen = new Generation();
+        Message userMsg = Message.builder()
+                .role(Role.USER.getValue())
+                .content(dto.getContent())
+                .build();
+        TranslationOptions options = TranslationOptions.builder()
+                .sourceLang(dto.getSourceLang())
+                .targetLang(dto.getTargetLang())
+                .build();
+        GenerationParam param = GenerationParam.builder()
+                // 若没有配置环境变量,请用阿里云百炼API Key将下行替换为:.apiKey("sk-xxx")
+                .apiKey("sk-babdcf8799144134915cee2683794b2f")
+                .model("qwen-mt-plus")
+                .messages(Collections.singletonList(userMsg))
+                .resultFormat(GenerationParam.ResultFormat.MESSAGE)
+                .translationOptions(options)
+                .build();
+        try {
+            GenerationResult result = gen.call(param);
+            String content = result.getOutput().getChoices().get(0).getMessage().getContent();
+            map.put("content", dto.getContent());
+            map.put("translate", content);
+            // 计算翻译耗时
+            long endTime = System.currentTimeMillis();
+            long duration = endTime - startTime;
+            map.put("durationMs", duration + "ms");
+        } catch (NoApiKeyException e) {
+            e.printStackTrace();
+        } catch (InputRequiredException e) {
+            e.printStackTrace();
+        }
+        return new FebsResponse().success().data(map);
+    }
+
 }

--
Gitblit v1.9.1