java調(diào)用通義千問(wèn)API的詳細(xì)完整步驟
前言
想問(wèn)問(wèn)大家,更喜歡用文心千帆還是通義千問(wèn)呢?排除openai
前面廢話比較多,更適合小白體質(zhì)的文章(不過(guò)學(xué)到這的應(yīng)該是中白吧)。=v=
申請(qǐng)通義千問(wèn)API
首先,找到通義千問(wèn)在哪里,直接在阿里云官網(wǎng)主頁(yè):
然后點(diǎn)擊搜索通義千問(wèn):
點(diǎn)擊申請(qǐng)通義千問(wèn)API:
我這里是第一次申請(qǐng),然后系統(tǒng)提示需要開通模型服務(wù)靈積,點(diǎn)擊去開通:
點(diǎn)擊已閱讀并同意:
然后好像是點(diǎn)擊確認(rèn),系統(tǒng)就會(huì)提示開通成功:
回到下圖的這個(gè)界面,點(diǎn)擊我已開通,刷新頁(yè)面(這步也可以在上一圖直接點(diǎn)擊前往控制臺(tái),然后在模型廣場(chǎng)的通義千問(wèn)下點(diǎn)擊申請(qǐng)?bào)w驗(yàn)):
此時(shí)需要填一個(gè)問(wèn)卷,模型名稱就是通義千問(wèn),其他信息如實(shí)填寫即可:
然后就是等待審核通過(guò)了:
此時(shí),原本申請(qǐng)?bào)w驗(yàn)就變成了體驗(yàn)申請(qǐng)審核中,請(qǐng)耐心等待的狀態(tài)了:
在等待審核中,讓我們看看讓人關(guān)心的計(jì)費(fèi)情況:-3:
下圖是文心千帆大模型的計(jì)費(fèi)情況(大模型訓(xùn)練里的服務(wù),都比預(yù)制服務(wù)的價(jià)格貴),對(duì)比起來(lái),都差不多,openai的其實(shí)價(jià)格換算一下,其實(shí)差不多,所以我選通義千問(wèn)(因?yàn)槲沂前祖喂?,而且我也不知道怎么給上線的服務(wù)器加魔法,如果是分布式的話,是每個(gè)服務(wù)器都要給魔法?):
然后就可以看看快速開始了:
ps:以上內(nèi)容是我第二次寫了,明明typora有設(shè)置自動(dòng)保存,但是電腦突然關(guān)機(jī)了,再打開,寫的東西就全沒(méi)了QAQ,所幸圖片還在。所以上面有個(gè)地方我有點(diǎn)回憶不起來(lái)了,不過(guò)不是大問(wèn)題。
不得不說(shuō),這審核通過(guò)的速度好快,我快速開始都還沒(méi)看個(gè)大概就申請(qǐng)通過(guò)了(我剛剛在申請(qǐng)公眾號(hào),還有設(shè)置typora圖片上傳到Gitee,看了一點(diǎn)別人寫的Java接入通義千問(wèn))??傊@個(gè)審核我這大概要等一兩小時(shí)(我看別人申請(qǐng)文心千帆要兩三天),審核通過(guò)后,會(huì)發(fā)短信到手機(jī)上:
然后就按照官方文檔繼續(xù)整吧。
前置工作
創(chuàng)建并獲取API-KEY
根據(jù)官方文檔說(shuō):
所以需要先獲取API-KEY:
復(fù)制并保存創(chuàng)建的API-KEY:
(ps:我這現(xiàn)在如果沒(méi)復(fù)制到API-KEY,可以通過(guò)安全驗(yàn)證的方式查看API-KEY,以后可能就不可以這樣了,所以還是好好保存吧)
安裝DashScope SDK
注意這樣要求Java SDK支持java8及以上環(huán)境:
在maven網(wǎng)站查看DashScope Java SDK
版本號(hào),我當(dāng)前查看的最新版本是2.3.0,所以我在pom.xml文件中添加以下依賴項(xiàng):
<!--https://mvnrepository.com/artifact/com.alibaba/dashscope-sdk-java --> <dependency> <groupId>com.alibaba</groupId> <artifactId>dashscope-sdk-java</artifactId> <version>2.1.1</version> </dependency>
然鵝,可能是我配置的鏡像還沒(méi)有2.3.0的版本,所以說(shuō)沒(méi)找到,所以我加載2.1.1的版本了。
另外,我這里應(yīng)該是DashScope依賴和項(xiàng)目里的其他依賴沖突了,出現(xiàn)報(bào)錯(cuò),有兩份酸辣粉4斤了(bushi):
SLF4J: Class path contains multiple SLF4J bindings. SLF4J: Found binding in [jar:file:/D:/Program%20Files/apache-maven-3.6.1/mvn_repo/ch/qos/logback/logback-classic/1.2.10/logback-classic-1.2.10.jar!/org/slf4j/impl/StaticLoggerBinder.class] SLF4J: Found binding in [jar:file:/D:/Program%20Files/apache-maven-3.6.1/mvn_repo/org/slf4j/slf4j-simple/1.7.36/slf4j-simple-1.7.36.jar!/org/slf4j/impl/StaticLoggerBinder.class] SLF4J: See http://www.slf4j.org/codes.html#multiple_bindings for an explanation. SLF4J: Actual binding is of type [ch.qos.logback.classic.util.ContextSelectorStaticBinder]
查到?jīng)_突的包:
對(duì)依賴添加排除依賴,然后就不會(huì)報(bào)依賴包沖突的錯(cuò)了,如下:
<dependency> <groupId>com.alibaba</groupId> <artifactId>dashscope-sdk-java</artifactId> <exclusions> <exclusion> <groupId>org.slf4j</groupId> <artifactId>slf4j-simple</artifactId> </exclusion> </exclusions> <version>2.1.1</version> </dependency>
參考博文:maven依賴包沖突如何處理 SLF4J: Class path contains multiple SLF4J bindings.。
代碼部分
通義千問(wèn)支持http調(diào)用,可以參考官方給出的請(qǐng)求和響應(yīng)實(shí)例:
再利用hutool來(lái)幫助代碼的編寫:
<!--添加hutool的依賴--> <dependency> <groupId>cn.hutool</groupId> <artifactId>hutool-all</artifactId> <version>5.8.16</version> </dependency>
Controller類:
import cn.hutool.http.HttpRequest; import cn.hutool.json.JSONUtil; import org.springframework.web.bind.annotation.PostMapping; import org.springframework.web.bind.annotation.RestController; //還需要引入下面兩個(gè)domain類 @RestController public class ChatController { @PostMapping("/chat")//文檔要求使用post請(qǐng)求 public ChatResponse chat(String q){ String url = "https://dashscope.aliyuncs.com/api/v1/services/aigc/text-generation/generation";//這里看官方文檔 String ApiKey = "sk-xxxxxxxxxx3d7fe";//這里換成你自己的ApiKey ChatRequest chatRequest = new ChatRequest(q); String json = JSONUtil.toJsonStr(chatRequest); //System.out.println(json);//正式發(fā)送給api前,查看請(qǐng)求的主要數(shù)據(jù)情況 String result = HttpRequest.post(url) .header("Authorization","Bearer "+ ApiKey) .header("Content-Type","application/json") .body(json) .execute().body(); System.out.println(result); return JSONUtil.toBean(result, ChatResponse.class); } }
domain類:
//這個(gè)是用來(lái)處理請(qǐng)求的 import lombok.AllArgsConstructor; import lombok.Data; import lombok.NoArgsConstructor; import java.util.ArrayList; import java.util.List; @Data @AllArgsConstructor @NoArgsConstructor public class ChatRequest { String model; Input input; Parameters parameters; public ChatRequest(String q){ model = "qwen-v1"; input = new Input(q); parameters = new Parameters(); } class Input { public List<Chat> messages; Input(String q){ ArrayList<ChatRequest.Chat> chats = new ArrayList<>(); chats.add(new Chat("system","你是達(dá)摩院的生活助手機(jī)器人。")); chats.add(new Chat("user",q)); messages = chats; } } class Chat { public String role; public String content; Chat(String role,String content){ this.role = role; this.content = content; } } class Parameters { public String result_format = "text"; } }
//這個(gè)是用來(lái)處理響應(yīng)的 import lombok.AllArgsConstructor; import lombok.Data; import lombok.NoArgsConstructor; @Data @AllArgsConstructor @NoArgsConstructor public class ChatResponse { Output output; Usage usage; String request_id; class Output{ public String text; public String finish_reason; } class Usage{ public String output_tokens; public String input_tokens; } }
啟動(dòng)項(xiàng)目,訪問(wèn)Knife4j的文檔地址http://localhost:8081/api/doc.html,測(cè)試后端api/chat端口(這里也可以用postman、apipost、apifox、Swagger等測(cè)試端口工具):
響應(yīng)數(shù)據(jù)為:
{ "output": { "text": "I am a large language model created by DAMO Academy. I am called QianWen.", "finish_reason": "stop" }, "usage": { "output_tokens": "20", "input_tokens": "30" }, "request_id": "1f92c2ac-ccb9-9498-9870-55fbc04d2e9c" }
我問(wèn)中文時(shí)候就是回中文,回答的語(yǔ)言可能和問(wèn)的語(yǔ)言有關(guān)吧
小結(jié)
可以在上面代碼的基礎(chǔ)上,根據(jù)自己的項(xiàng)目實(shí)際情況,進(jìn)行修改,上面的代碼只是對(duì)數(shù)據(jù)進(jìn)行了基礎(chǔ)的處理。
到此這篇關(guān)于java調(diào)用通義千問(wèn)API的文章就介紹到這了,更多相關(guān)java調(diào)用通義千問(wèn)API內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
spring?boot集成smart-doc自動(dòng)生成接口文檔詳解
這篇文章主要介紹了spring?boot集成smart-doc自動(dòng)生成接口文檔詳解,smart-doc是一款同時(shí)支持java?restful?api和Apache?Dubbo?rpc接口文檔生成的工具,smart-doc顛覆了傳統(tǒng)類似swagger這種大量采用注解侵入來(lái)生成文檔的實(shí)現(xiàn)方法2022-09-09一文搞懂如何實(shí)現(xiàn)Java,Spring動(dòng)態(tài)啟停定時(shí)任務(wù)
定時(shí)任務(wù)的應(yīng)用場(chǎng)景十分廣泛,如定時(shí)清理文件、定時(shí)生成報(bào)表、定時(shí)數(shù)據(jù)同步備份等。本文將教你實(shí)現(xiàn)Java、Spring動(dòng)態(tài)啟停定時(shí)任務(wù),感興趣的可以學(xué)習(xí)一下2022-06-06IDEA+JRebel實(shí)現(xiàn)全自動(dòng)熱部署的方法步驟
這篇文章主要介紹了IDEA+JRebel實(shí)現(xiàn)全自動(dòng)熱部署的方法步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-11-11SpringBoot 項(xiàng)目中的圖片處理策略之本地存儲(chǔ)與路徑映射
在SpringBoot項(xiàng)目中,靜態(tài)資源存放在static目錄下,使得前端可以通過(guò)URL來(lái)訪問(wèn)這些資源,我們就需要將文件系統(tǒng)的文件路徑與URL建立一個(gè)映射關(guān)系,把文件系統(tǒng)中的文件當(dāng)成我們的靜態(tài)資源即可,本文給大家介紹SpringBoot本地存儲(chǔ)與路徑映射的相關(guān)知識(shí),感興趣的朋友一起看看吧2023-12-12利用Java如何獲取Mybatis動(dòng)態(tài)生成的sql接口實(shí)現(xiàn)
MyBatis 的強(qiáng)大特性之一便是它的動(dòng)態(tài)SQL,下面這篇文章主要給大家介紹了關(guān)于利用Java如何獲取Mybatis動(dòng)態(tài)生成的sql接口實(shí)現(xiàn)的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-01-01