mirror of
				https://gitee.com/hhyykk/ipms-sjy.git
				synced 2025-10-31 18:28:43 +08:00 
			
		
		
		
	【功能新增】AI:集成 Azure 的 OpenAI 模型
This commit is contained in:
		| @@ -0,0 +1,70 @@ | ||||
| package cn.iocoder.yudao.framework.ai.chat; | ||||
|  | ||||
| import com.azure.ai.openai.OpenAIClient; | ||||
| import com.azure.ai.openai.OpenAIClientBuilder; | ||||
| import com.azure.core.credential.AzureKeyCredential; | ||||
| import com.azure.core.util.ClientOptions; | ||||
| import org.junit.jupiter.api.Disabled; | ||||
| import org.junit.jupiter.api.Test; | ||||
| import org.springframework.ai.azure.openai.AzureOpenAiChatModel; | ||||
| import org.springframework.ai.azure.openai.AzureOpenAiChatOptions; | ||||
| import org.springframework.ai.chat.messages.Message; | ||||
| import org.springframework.ai.chat.messages.SystemMessage; | ||||
| import org.springframework.ai.chat.messages.UserMessage; | ||||
| import org.springframework.ai.chat.model.ChatResponse; | ||||
| import org.springframework.ai.chat.prompt.Prompt; | ||||
| import reactor.core.publisher.Flux; | ||||
|  | ||||
| import java.util.ArrayList; | ||||
| import java.util.List; | ||||
|  | ||||
| import static org.springframework.ai.autoconfigure.azure.openai.AzureOpenAiChatProperties.DEFAULT_DEPLOYMENT_NAME; | ||||
|  | ||||
| /** | ||||
|  * {@link AzureOpenAiChatModel} 集成测试 | ||||
|  * | ||||
|  * @author 芋道源码 | ||||
|  */ | ||||
| public class AzureOpenAIChatModelTests { | ||||
|  | ||||
|     private final OpenAIClient openAiApi = (new OpenAIClientBuilder()) | ||||
|             .endpoint("https://eastusprejade.openai.azure.com") | ||||
|             .credential(new AzureKeyCredential("xxx")) | ||||
|             .clientOptions((new ClientOptions()).setApplicationId("spring-ai")) | ||||
|             .buildClient(); | ||||
|     private final AzureOpenAiChatModel chatModel = new AzureOpenAiChatModel(openAiApi, | ||||
|             AzureOpenAiChatOptions.builder().withDeploymentName(DEFAULT_DEPLOYMENT_NAME).build()); | ||||
|  | ||||
|     @Test | ||||
|     @Disabled | ||||
|     public void testCall() { | ||||
|         // 准备参数 | ||||
|         List<Message> messages = new ArrayList<>(); | ||||
|         messages.add(new SystemMessage("你是一个优质的文言文作者,用文言文描述着各城市的人文风景。")); | ||||
|         messages.add(new UserMessage("1 + 1 = ?")); | ||||
|  | ||||
|         // 调用 | ||||
|         ChatResponse response = chatModel.call(new Prompt(messages)); | ||||
|         // 打印结果 | ||||
|         System.out.println(response); | ||||
|         System.out.println(response.getResult().getOutput()); | ||||
|     } | ||||
|  | ||||
|     @Test | ||||
|     @Disabled | ||||
|     public void testStream() { | ||||
|         // 准备参数 | ||||
|         List<Message> messages = new ArrayList<>(); | ||||
|         messages.add(new SystemMessage("你是一个优质的文言文作者,用文言文描述着各城市的人文风景。")); | ||||
|         messages.add(new UserMessage("1 + 1 = ?")); | ||||
|  | ||||
|         // 调用 | ||||
|         Flux<ChatResponse> flux = chatModel.stream(new Prompt(messages)); | ||||
|         // 打印结果 | ||||
|         flux.doOnNext(response -> { | ||||
| //            System.out.println(response); | ||||
|             System.out.println(response.getResult().getOutput()); | ||||
|         }).then().block(); | ||||
|     } | ||||
|  | ||||
| } | ||||
| @@ -1,6 +1,5 @@ | ||||
| package cn.iocoder.yudao.framework.ai.chat; | ||||
|  | ||||
| import cn.iocoder.yudao.framework.ai.core.model.xinghuo.XingHuoChatModel; | ||||
| import org.junit.jupiter.api.Disabled; | ||||
| import org.junit.jupiter.api.Test; | ||||
| import org.springframework.ai.chat.messages.Message; | ||||
| @@ -17,7 +16,7 @@ import java.util.ArrayList; | ||||
| import java.util.List; | ||||
|  | ||||
| /** | ||||
|  * {@link XingHuoChatModel} 集成测试 | ||||
|  * {@link OpenAiChatModel} 集成测试 | ||||
|  * | ||||
|  * @author 芋道源码 | ||||
|  */ | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 YunaiV
					YunaiV