一、开通服务并获得API-KEY
-
访问DashScope管理控制台:前往控制台。
-
在控制台“总览”页下,点击“去开通
-
创建API-KEY
二、接入SpringBoot项目中
1、添加DashScope SDK依赖
maven地址:https://mvnrepository.com/artifact/com.alibaba/dashscope-sdk-java
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>dashscope-sdk-java</artifactId>
<version>2.14.0</version>
</dependency>
2、配置文件
3、注入Generation对象
@Configuration
public class AliAiConfig {
@Bean
public Generation generation() {
return new Generation();
}
}
4、controller代码
package com.springai.alityqwdemo.controller;
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.common.Message;
import com.alibaba.dashscope.common.Role;
import com.alibaba.dashscope.exception.InputRequiredException;
import com.alibaba.dashscope.exception.NoApiKeyException;
import com.springai.alityqwdemo.utils.TyqwUtil;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import javax.annotation.Resource;
import java.util.Arrays;
@RestController
@RequestMapping("ai/")
public class AliAliController {
@Value("${ai-api-key}")
private String apiKey;
@Resource
private Generation generation;
/**
* 测试demo
* @param content 用书输入文本内容
*/
@PostMapping(value = "aliTyqw")
public String send(@RequestBody String content) throws NoApiKeyException, InputRequiredException {
//用户与模型的对话历史。list中的每个元素形式为{“role”:角色, “content”: 内容}。
Message userMessage = Message.builder()
.role(Role.USER.getValue())
.content(content)
.build();
GenerationParam param = GenerationParam.builder()
//指定用于对话的通义千问模型名
.model("qwen-turbo")
.messages(Arrays.asList(userMessage))
//
.resultFormat(GenerationParam.ResultFormat.MESSAGE)
//生成过程中核采样方法概率阈值,例如,取值为0.8时,仅保留概率加起来大于等于0.8的最可能token的最小集合作为候选集。
// 取值范围为(0,1.0),取值越大,生成的随机性越高;取值越低,生成的确定性越高。
.topP(0.8)
//阿里云控制台DASHSCOPE获取的api-key
.apiKey(apiKey)
//启用互联网搜索,模型会将搜索结果作为文本生成过程中的参考信息,但模型会基于其内部逻辑“自行判断”是否使用互联网搜索结果。
.enableSearch(true)
.build();
GenerationResult generationResult =generation.call(param);;
return generationResult.getOutput().getChoices().get(0).getMessage().getContent();
}
}
5、postman测试
官方api详情文档:如何使用通义千问API_模型服务灵积(DashScope)-阿里云帮助中心