Spring AI 整合openAI的chatGpt

Spring AI支持ChatGPT,这是OpenAI的AI语言模型。ChatGPT在激发人们对人工智能驱动文本生成的兴趣方面发挥了重要作用。

SpringAi与Spring Boot 的整合详见上一篇文章:
Spring AI 介绍以及与 Spring Boot 项目整合

下面分四个部分来分别说明和演示,假设你已经完整地整合了Spring Ai,并且在配置文件里正确地配置了open ai key等参数。

1. 直接传入问题,生成最终结果后返回。

@RestController
@RequestMapping("/openai")
public class OpenAiChatController {

    @Resource
    private OpenAiChatModel openAiChatModel;


    // 定义一个接口,直接使用String参数类型
    @GetMapping("/chat/generate1")
    public String chat(@RequestParam(value = "message",defaultValue = "你是谁?") String message) {
        // 调用OpenAI聊天模型的call方法,传入message参数,得到返回结果
        String result = openAiChatModel.call(message);
        // 打印返回结果
        System.out.println(result);
        // 返回结果
        return  result;
    }
}

在这里插入图片描述

2.传入Prompt对象参数,生成最终结果后返回。

@RestController
@RequestMapping("/openai")
public class OpenAiChatController {

    @Resource
    private OpenAiChatModel openAiChatModel;


     // 定义一个方法,使用Prompt对象作为参数
    @GetMapping("/chat/generate2")
    public ChatResponse chat2(@RequestParam(value = "message",defaultValue = "你是谁?") String message) {
        // 调用openAiChatModel的call方法,传入Prompt对象,Prompt对象包含message和OpenAiChatOptions对象
        ChatResponse callResponse = openAiChatModel.call(new Prompt(message,
                OpenAiChatOptions.builder()
                        .withModel("gpt-3.5-turbo")  //指定模型的名称,gpt有很多模型,如gpt3.5,gpt-4o等,这里可以指定
                        .withTemperature(0.6f) //指定生成文本的匹配度,越高越创新,越低越保守。0.6是一个比较合适的值
                        .build()
         ));
        // 获取callResponse的result对象,然后获取output对象,最后获取content对象
        String result = callResponse.getResult().getOutput().getContent();
        System.out.println(result);
        // 返回callResponse
        return  callResponse;
    }
    }

在这里插入图片描述

3.直接传入问题,流式返回结果。

@RestController
@RequestMapping("/openai")
public class OpenAiChatController {

    @Resource
    private OpenAiChatModel openAiChatModel;


    // 定义一个接口,使用Prompt对象作为参数, 使用流式输出
    @GetMapping("/chat/generate3")
    public Object chat3(@RequestParam(value = "message",defaultValue = "你是谁?") String message) {
        // 调用OpenAI聊天模型的call方法,传入message参数,得到返回结果
        Flux<String> stream = openAiChatModel.stream(message);
        stream.toStream().forEach(System.out::println);
        // 返回结果
        return  stream.collectList();
    }
}

在这里插入图片描述

4.传入prompt,流式返回结果。

@RestController
@RequestMapping("/openai")
public class OpenAiChatController {

    @Resource
    private OpenAiChatModel openAiChatModel;


    // 定义一个接口,直接使用String参数类型, 使用流式输出
    @GetMapping("/chat/generate4")
    public Object chat4(@RequestParam(value = "message",defaultValue = "你是谁?") String message) {
        // 调用OpenAI聊天模型的call方法,传入message参数,得到返回结果
        Flux<ChatResponse> stream = openAiChatModel.stream(new Prompt(message));
        stream.toStream().forEach(System.out::println);
        // 返回结果
        return  stream.collectList();
    }
}

在这里插入图片描述

  • 13
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Spring 是一个开源框架,主要用于构建基于 Java 平台的应用程序。而 C知道助手 则是由 CSDN 训练的大型语言模型,用于生成自然语言文本。 要将 SpringChatGPT 整合在一起,需要先确定具体的应用场景和需求。一般来说,可以使用 Spring 提供的 RESTful API 功能来与 ChatGPT 进行交互,实现通过 HTTP 请求发送文本到 ChatGPT 并获取其生成的响应文本的功能。 具体实现过程可以参考以下步骤: 1. 创建一个 Spring Boot 应用程序,并在其中添加所需的依赖,例如 Spring Web、Jackson 等。 2. 编写一个 RESTful Controller,用于接收 HTTP 请求,并将请求中的文本发送到 ChatGPT 进行处理。可以使用 OpenAI 提供的 API 或者使用类似 OpenAI GPT 的开源库在本地搭建 GPT 模型。 3. 在 Controller 中调用 ChatGPT 的 API 或本地 GPT 模型的接口,将请求中的文本传递给 ChatGPT 并获取其生成的响应文本。 4. 将生成的响应文本返回给客户端,完成整个流程。 需要注意的是,在整合 SpringChatGPT 的过程中,需要考虑到安全性、性能、可扩展性等方面的问题,并进行充分的测试和优化。 ### 回答2: 要将ChatGPT整合Spring中,可以按照以下步骤进行操作: 1. 配置ChatGPT模型:首先,应该选择一个合适的ChatGPT模型。它可以在本地或通过云服务进行部署。确保为模型选择一个唯一的标识符。 2. 创建Spring项目:使用Spring Boot创建一个新的项目。 3. 添加依赖:在项目的pom.xml(如果使用Maven)或build.gradle(如果使用Gradle)文件中,添加ChatGPT相关的依赖项。例如,如果使用OpenAI官方提供的Python库,则需要添加相应的依赖项。 4. 实现ChatGPT客户端:在Spring项目中创建一个类,用于与ChatGPT进行通信。这个客户端类应该包含与ChatGPT模型交互的代码,如发送请求和接收响应。 5. 创建Spring控制器:在Spring项目中创建一个控制器类,用于处理与ChatGPT客户端的交互。这个类应该包含与前端界面的交互,并将请求转发给ChatGPT客户端来获取响应。 6. 设计和开发前端界面:创建一个Spring的视图模板,用于显示交互式聊天界面。该界面应该收集用户输入并将其发送给Spring控制器进行处理。 7. 部署和运行:将Spring项目部署到服务器上,并确保ChatGPT模型可以与其正确通信。运行应用程序,并通过浏览器访问前端界面以开始与ChatGPT进行互动。 整合ChatGPTSpring项目中,需要对ChatGPT的API和Spring的组件进行适当配置和开发。这样就可以通过前端界面与ChatGPT进行聊天的交互了。注意确保ChatGPT模型的性能和安全性,并根据需求进行适当的调整和优化。 ### 回答3: 要将Spring整合ChatGPT,可以按照以下步骤进行: 1. 首先,确保已经安装并配置了Spring框架和ChatGPT的Python库。可以使用Maven或Gradle等构建工具添加所需的依赖。 2. 创建一个Spring Boot项目,并在pom.xml(如果使用Maven)或build.gradle(如果使用Gradle)文件中添加ChatGPT库的依赖项。 3. 在Spring Boot项目中创建一个Controller类,该类将处理与ChatGPT的交互。可以使用@RestController注解将该类声明为一个RESTful服务。 4. 在Controller中,创建一个post方法来接收用户输入的文本或问题作为请求的参数。可以使用@RequestBody注解将请求体中的数据绑定到方法的参数上。 5. 在方法中,使用ChatGPT的API或库方法来调用ChatGPT模型,并传入用户输入的文本。可以使用ChatGPT的generate方法生成聊天回复。 6. 将ChatGPT的生成的回复作为响应返回给客户端。可以使用@ResponseBody注解将方法的返回值直接作为响应体返回。 7. 运行Spring Boot应用程序,并确保ChatGPT的服务也在运行并可被访问。 8. 使用HTTP客户端(如Postman或浏览器)向Spring应用程序的Controller发送请求,并查看响应中ChatGPT生成的回复。 这样,我们就实现了将SpringChatGPT整合,使得Spring应用程序可以根据用户的输入调用ChatGPT模型并生成聊天回复。这种整合可以让Spring应用程序具备聊天机器人的功能,与用户进行即时的对话交流。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值