Sping boot 整合chatGPT

一、介绍

        Spring Boot 是一种用于创建独立的、基于 Spring 的应用程序的框架。它的主要目的是简化 Spring 应用程序的开发和部署过程。在本文中,我将向您展示如何使用 Spring Boot 框架与 ChatGPT 进行整合。

二、获取api密钥

OpenAI API

 注意,不会在生成秘密API密钥后再次显示密钥。

三、整合chatGPT

1、pom.xml中添加依赖

     <dependency>
            <groupId>com.theokanning.openai-gpt3-java</groupId>
            <artifactId>service</artifactId>
            <version>0.11.0</version>
     </dependency>
     <dependency>
            <groupId>com.theokanning.openai-gpt3-java</groupId>
            <artifactId>client</artifactId>
            <version>0.11.0</version>
     </dependency>

2、domain

package com.lxy.openai.domain;

import lombok.Data;

/**
 * @author lixingyu
 */
@Data
public class OpenAi {
    String model;
    Double temperature;
    Double topP;
    Double frequencyPenalty;
    Double presencePenalty;
    String stop;

    String role;

    public OpenAi(String model,Double temperature, Double topP, Double frequencyPenalty, Double presencePenalty) {
        this.model = model;
        this.temperature = temperature;
        this.topP = topP;
        this.frequencyPenalty = frequencyPenalty;
        this.presencePenalty = presencePenalty;
    }
}

3、工具类编写

package com.lxy.openai.utils;

import com.lxy.openai.domain.OpenAi;
import com.theokanning.openai.completion.chat.ChatCompletionChoice;
import com.theokanning.openai.completion.chat.ChatCompletionRequest;
import com.theokanning.openai.completion.chat.ChatMessage;
import com.theokanning.openai.service.OpenAiService;
import com.theokanning.openai.completion.CompletionChoice;
import com.theokanning.openai.completion.CompletionRequest;
import java.time.Duration;
import java.util.*;


/**
 * 调用OpenAi的gpt-3.5-turbo 与 text-davinci-003
 *
 * @author lixingyu
 */
public class OpenAiUtils {

    public static String API_KEY = "api密钥";
    public static Duration TIMEOUT = Duration.ofSeconds(300);

    public static final Map<String, OpenAi> DEFAULT_MODEL= new HashMap<>();

    static {
        DEFAULT_MODEL.put("turbo", new OpenAi("gpt-3.5-turbo", 0.2, 0.1, 2d, 2d));
        DEFAULT_MODEL.put("davinci-003", new OpenAi("text-davinci-003",  0.9, 0.1, 1.0, 1.0));
    }

    /**
     * 获取ai
     *
     * @param openAi
     * @param prompt
     * @return
     */
    public static List<CompletionChoice> getAiResult(OpenAi openAi, String prompt) {
        OpenAiService service = new OpenAiService(API_KEY, TIMEOUT);
        CompletionRequest.CompletionRequestBuilder builder = CompletionRequest.builder()
                .model(openAi.getModel())
                .prompt(prompt)
                .temperature(openAi.getTemperature())
                .maxTokens(1000)
                .topP(openAi.getTopP())
                .frequencyPenalty(openAi.getFrequencyPenalty())
                .presencePenalty(openAi.getPresencePenalty());
        CompletionRequest completionRequest = builder.build();
        return service.createCompletion(completionRequest).getChoices();

    }
    public static List<ChatCompletionChoice> getAiChatResult(OpenAi openAi, String prompt) {
        OpenAiService service = new OpenAiService(API_KEY, TIMEOUT);
        List<ChatMessage> messageList = new ArrayList<>();
        ChatMessage message = new ChatMessage();
        message.setContent(prompt);
        message.setRole("user");
        messageList.add(message);
        ChatCompletionRequest.ChatCompletionRequestBuilder requestBuilder = ChatCompletionRequest.builder() .model(openAi.getModel())
                .messages(messageList)
                .temperature(openAi.getTemperature())
                .maxTokens(3000)
                .topP(openAi.getTopP())
                .frequencyPenalty(openAi.getFrequencyPenalty())
                .presencePenalty(openAi.getPresencePenalty());
        ChatCompletionRequest build = requestBuilder.build();
        return service.createChatCompletion(build).getChoices();
    }


    /**
     * 文本
     * @param text 文本
     * @return
     */
    public static List<CompletionChoice> getRating(String text) {
        OpenAi openAi = DEFAULT_MODEL.get("davinci-003");
        return getAiResult(openAi, text);
    }

    /**
     * GPT-3.5型号
     * @param text 文本
     * @return
     */
    public static List<ChatCompletionChoice> getChatRating(String text) {
        OpenAi openAi = DEFAULT_MODEL.get("turbo");
        return getAiChatResult(openAi, text);
    }


}

四、总结

本文主要使用gpt-3.5-turbo与text-davinci-003,具体接口说明可参考官方说明OpenAI API。GPT-4是OpenAI最新推出的语言模型,但是它目前仍处于测试阶段,并且只向少数研究人员和企业客户授予了访问权限。此外,OpenAI也已经更新了API的定价和使用方式,需要访问他们的网站获取更多信息。

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
### 回答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应用程序具备聊天机器人的功能,与用户进行即时的对话交流。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Fashionable ape man

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值