From 70f773b88de5041481374387e538d8cec1149fff Mon Sep 17 00:00:00 2001
From: Administrator <15274802129@163.com>
Date: Wed, 25 Feb 2026 17:15:18 +0800
Subject: [PATCH] feat(ai): 添加产品要点信息中的公司ID字段
---
src/main/java/cc/mrbird/febs/ai/service/impl/AiProductServiceImpl.java | 54 ++++++++++++++++++++++++++++++++++++++++++++++++++----
1 files changed, 50 insertions(+), 4 deletions(-)
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