成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

我給清華智譜Ai(ChatGLM),寫個Java對接的SDK!

開發 項目管理
智譜Ai的Api文檔,與ChatGPT對接有一些差異。如果大家對接過ChatGPT開發,直接獲取一個ApiKey就可以使用了。但在對接智譜Ai的Api時,需要把獲取的ApiKey按照.號分割,并需要進行JWT-Token的創建。而這個Token才是實際傳給接口的內容。

大家好,我是技術UP主小傅哥。

清華大學計算機系的超大規模訓練模型 ChatGLM-130B 使用效果非常牛,所以我也想把這樣的Ai能力接入到自己的應用中或者做一些 IntelliJ IDEA Plugin 使用。但經過了一晚上的折騰,我決定給它寫個對接的SDK開源出來!—— ?? 智譜Ai不是已經有了一個SDK嗎?為啥還要寫呢?那你寫多少了?

在很早之前就關注了智譜Ai(ChatGLM),也看到官網有一個Java對接的SDK方式。但從前幾天開始正式對接發現,這SDK是8月份提交的,10個commit,而且已經2個月沒有更新了。所以真的是不少Bug呀,呀,呀!如果不去修改它的SDK代碼,就沒法對接。如;ConfigV3類中,拆分ApiKey的操作;String[] arrStr = apiSecretKey.split("."); 但這里的.是正則的關鍵字,所以根本沒法拆分。一起動就報錯 invalid apiSecretKey 這對于初次對接并且沒有看源碼的伙伴來說,是不小的炸雷。

不過,雖然 SDK 有點趕工,不好用。但不影響智譜Ai(ChatGLM)是個好東西。他的官網中有API HTTP 接口對接描述。所以,小傅哥決定跟著按照它的文檔寫一個能簡單對接,代碼有干凈整潔的 SDK 讓大家使用。

圖片圖片

那么,接下來小傅哥就介紹下,如何基于智譜Ai(ChatGLM)的開發者文檔,開發一個通用的SDK組件。也讓后續有想法PR貢獻源碼的伙伴,一起參與進來。—— 別看東西不大,寫到簡歷上,也是非常精彩的一筆!

本文不止有智譜Ai-SDK開發,還有如何在項目中運用SDK開發一個自己的OpenAi服務。文末有SDK鏈接和OpenAi應用工程。

一、對接鑒權

  • 文檔:https://open.bigmodel.cn/dev/api
  • ApiKey:https://open.bigmodel.cn/usercenter/apikeys - 申請個人授權,創建ApiKey即可

智譜Ai的Api文檔,與ChatGPT對接有一些差異。如果大家對接過ChatGPT開發,直接獲取一個ApiKey就可以使用了。但在對接智譜Ai的Api時,需要把獲取的ApiKey按照.號分割,并需要進行JWT-Token的創建。而這個Token才是實際傳給接口的內容。

圖片圖片

  • 因為生成Token會比較耗時,所以這里會使用Guava框架進行本地緩存29分鐘,有效期30分鐘的Token,確保可以有效的刷新。
  • 在工程中提供了 BearerTokenUtils Token 生成工具類,測試的時候可以使用。

二、接口處理

文檔:https://open.bigmodel.cn/dev/api#chatglm_lite - 以Api文檔的chatglm_lite模型舉例對接

傳輸方式

https

請求地址

https://open.bigmodel.cn/api/paas/v3/model-api/chatglm_lite/sse-invoke

調用方式

SSE

字符編碼

UTF-8

接口請求頭

accept: text/event-stream

接口請求格式

JSON

響應格式

標準 Event Stream

接口請求類型

POST

開發語言

任意可發起 HTTP 請求的開發語言

在正式開發代碼,要把接口的使用先簡單測試運行出來。之后再去編寫代碼。為此這里小傅哥先根據官網的文檔和鑒權使用方式,編寫了 curl http 請求;

curl -X POST \
        -H "Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiIsInNpZ25fdHlwZSI6IlNJR04ifQ.eyJhcGlfa2V5IjoiNGUwODdlNDEzNTMwNmVmNGE2NzZmMGNjZTNjZWU1NjAiLCJleHAiOjE2OTY5OTM5ODIzMTQsInRpbWVzdGFtcCI6MTY5Njk5MjE4MjMxNH0.9nxhRXTJcP4Q_YTQ8w5y0CZOBOu0epP1J56oDaYewQ8" \
        -H "Content-Type: application/json" \
        -H "User-Agent: Mozilla/4.0 (compatible; MSIE 5.0; Windows NT; DigExt)" \
        -H "Accept: text/event-stream" \
        -d '{
        "top_p": 0.7,
        "sseFormat": "data",
        "temperature": 0.9,
        "incremental": true,
        "request_id": "xfg-1696992276607",
        "prompt": [
        {
        "role": "user",
        "content": "寫個java冒泡排序"
        }
        ]
        }' \
  http://open.bigmodel.cn/api/paas/v3/model-api/chatglm_lite/sse-invoke

圖片圖片

  • 注意:Authorization: Bearer 后面傳的是 JWT Token 不是一個直接從官網復制的 ApiKey - 你可以使用工程中的 BearerTokenUtils 創建。
  • 之后可以直接運行這段腳本(也可以導入到ApiPost工具中),執行后就能獲得到運行效果了。—— 速度非常快!

三、組件開發

在??考慮到抽象和設計原則下,小傅哥這里采用了會話模型結構進行工程框架設計。把程序的調用抽象為一次會話,而會話的創建則交給工廠??。通過工廠屏蔽使用細節,在使用上簡化調用,盡可能讓外部最少知道原則。這樣的設計實現方式,既可以滿足調用方開心的使用,也可以讓SDK貢獻者見代碼如見文檔,容易理解和上手。

1. 工程結構

圖片圖片

  • 工程非常注重會話的設計和使用,因為框架的根基搭建好以后,擴展各項功能就會有跡可循。大部分代碼就是因為早期沒有考慮好框架,最后功能來了被填充的很亂。

2. 會話流程

圖片圖片

  • 會話流程以工廠創建 Session 為入口點進行使用,其他的操作都在組件內自己處理好。

3. 代碼舉例

@Override
public OpenAiSession openSession() {
    // 1. 日志配置
    HttpLoggingInterceptor httpLoggingInterceptor = new HttpLoggingInterceptor();
    httpLoggingInterceptor.setLevel(configuration.getLevel());
    
    // 2. 開啟 Http 客戶端
    OkHttpClient okHttpClient = new OkHttpClient
            .Builder()
            .addInterceptor(httpLoggingInterceptor)
            .addInterceptor(new OpenAiHTTPInterceptor(configuration))
            .connectTimeout(configuration.getConnectTimeout(), TimeUnit.SECONDS)
            .writeTimeout(configuration.getWriteTimeout(), TimeUnit.SECONDS)
            .readTimeout(configuration.getReadTimeout(), TimeUnit.SECONDS)
            .build();
    configuration.setOkHttpClient(okHttpClient);
    
    // 3. 創建 API 服務
    IOpenAiApi openAiApi = new Retrofit.Builder()
            .baseUrl(configuration.getApiHost())
            .client(okHttpClient)
            .addCallAdapterFactory(RxJava2CallAdapterFactory.create())
            .addConverterFactory(JacksonConverterFactory.create())
            .build().create(IOpenAiApi.class);
    configuration.setOpenAiApi(openAiApi);
    return new DefaultOpenAiSession(configuration);
}
  • 這是一段 DefaultOpenAiSessionFactory 創建工廠開啟會話的服務對象。使用方只需要在自己的工程中,創建出一個工廠對象就可以對接使用了。下文有代碼示例
  • 其他更多的代碼,直接看小傅哥開發好的 chatglm-sdk-java

四、組件使用

1. 組件配置

  • 申請ApiKey:https://open.bigmodel.cn/usercenter/apikeys - 注冊申請開通,即可獲得 ApiKey
  • 運行環境:JDK 1.8+
  • maven pom - 暫時測試階段,未推送到Maven中央倉庫,需要下載代碼本地 install 后使用
<dependency>
    <groupId>cn.bugstack</groupId>
    <artifactId>chatglm-sdk-java</artifactId>
    <version>1.0-SNAPSHOT</version>
</dependency>
  • 源碼(Github):https://github.com/fuzhengwei/chatglm-sdk-java
  • 源碼(Gitee):https://gitee.com/fustack/chatglm-sdk-java
  • 源碼(Gitcode):https://gitcode.net/KnowledgePlanet/road-map/chatglm-sdk-java

2. 單元測試

@Slf4j
public class ApiTest {

    private OpenAiSession openAiSession;

    @Before
    public void test_OpenAiSessionFactory() {
        // 1. 配置文件
        Configuration configuration = new Configuration();
        configuration.setApiHost("https://open.bigmodel.cn/");
        configuration.setApiSecretKey("4e087e4135306ef4a676f0cce3cee560.sgP2*****");
        // 2. 會話工廠
        OpenAiSessionFactory factory = new DefaultOpenAiSessionFactory(configuration);
        // 3. 開啟會話
        this.openAiSession = factory.openSession();
    }

    /**
     * 流式對話
     */
    @Test
    public void test_completions() throws JsonProcessingException, InterruptedException {
        // 入參;模型、請求信息
        ChatCompletionRequest request = new ChatCompletionRequest();
        request.setModel(Model.CHATGLM_LITE); // chatGLM_6b_SSE、chatglm_lite、chatglm_lite_32k、chatglm_std、chatglm_pro
        request.setPrompt(new ArrayList<ChatCompletionRequest.Prompt>() {
            private static final long serialVersionUID = -7988151926241837899L;

            {
                add(ChatCompletionRequest.Prompt.builder()
                        .role(Role.user.getCode())
                        .content("寫個java冒泡排序")
                        .build());
            }
        });

        // 請求
        openAiSession.completions(request, new EventSourceListener() {
            @Override
            public void onEvent(EventSource eventSource, @Nullable String id, @Nullable String type, String data) {
                ChatCompletionResponse response = JSON.parseObject(data, ChatCompletionResponse.class);
                log.info("測試結果 onEvent:{}", response.getData());
                // type 消息類型,add 增量,finish 結束,error 錯誤,interrupted 中斷
                if (EventType.finish.getCode().equals(type)) {
                    ChatCompletionResponse.Meta meta = JSON.parseObject(response.getMeta(), ChatCompletionResponse.Meta.class);
                    log.info("[輸出結束] Tokens {}", JSON.toJSONString(meta));
                }
            }

            @Override
            public void onClosed(EventSource eventSource) {
                log.info("對話完成");
            }
        });

        // 等待
        new CountDownLatch(1).await();
    }

}
  • 這是一個單元測試類,也是最常使用的流式對話模式。

五、應用接入

1. SpringBoot 配置類

@Configuration
@EnableConfigurationProperties(ChatGLMSDKConfigProperties.class)
public class ChatGLMSDKConfig {

    @Bean
    @ConditionalOnProperty(value = "chatglm.sdk.config.enabled", havingValue = "true", matchIfMissing = false)
    public OpenAiSession openAiSession(ChatGLMSDKConfigProperties properties) {
        // 1. 配置文件
        cn.bugstack.chatglm.session.Configuration configuration = new cn.bugstack.chatglm.session.Configuration();
        configuration.setApiHost(properties.getApiHost());
        configuration.setApiSecretKey(properties.getApiSecretKey());

        // 2. 會話工廠
        OpenAiSessionFactory factory = new DefaultOpenAiSessionFactory(configuration);

        // 3. 開啟會話
        return factory.openSession();
    }

}

@Data
@ConfigurationProperties(prefix = "chatglm.sdk.config", ignoreInvalidFields = true)
public class ChatGLMSDKConfigProperties {

    /** 狀態;open = 開啟、close 關閉 */
    private boolean enable;
    /** 轉發地址 */
    private String apiHost;
    /** 可以申請 sk-*** */
    private String apiSecretKey;

}
@Autowired(required = false)
private OpenAiSession openAiSession;
  • 注意:如果你在服務中配置了關閉啟動 ChatGLM SDK 那么注入 openAiSession 為 null

2. yml 配置

# ChatGLM SDK Config
chatglm:
  sdk:
    config:
      # 狀態;true = 開啟、false 關閉
      enabled: false
      # 官網地址 
      api-host: https://open.bigmodel.cn/
      # 官網申請 https://open.bigmodel.cn/usercenter/apikeys
      api-key: 4e087e4135306ef4a676f0cce3cee560.sgP2DUs*****
  • 你可以在配置文件中,通過 enabled 參數,啟動和關閉 ChatGLM SDK

六、應用開發

基于本文開發的 ChatGLM SDK 就可以對接到 OpenAi 開發一個自己的應用了。

圖片圖片

小傅哥帶著大家寫的項目,從來不是湊數項目,也從不寫一堆的 CRUD 代碼。而是按照互聯網企業級中所開發項目的模式進行架構、設計和實現。所以你跟著小傅哥學習,學的是編程的思維和編碼的能力。

責任編輯:武曉燕 來源: bugstack蟲洞棧
相關推薦

2023-06-28 18:52:53

火山引擎智譜AI

2021-09-29 10:10:56

人工智能技術清華

2024-06-06 09:01:00

2025-02-14 09:21:04

2023-10-10 13:42:56

訓練數據

2023-09-19 09:20:16

2025-04-15 19:52:04

2023-12-19 18:12:25

谷歌模型AI

2023-03-15 09:36:14

模型

2025-02-14 09:50:00

DeepSeekAI

2018-12-20 09:52:05

JVM內存分配

2019-07-31 15:35:26

AI啤酒人工智能

2024-05-24 09:52:09

點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 91美女在线观看 | 亚洲精品在线观看网站 | 国产亚洲精品久久久优势 | 午夜91| 91中文字幕在线 | 久久91精品国产 | 本道综合精品 | 欧美久久国产精品 | 激情毛片| 亚洲劲爆av| 欧美视频1区 | 色综合99| 91在线精品播放 | 日本高清在线一区 | 成人激情视频 | 国产精品美女久久久久久免费 | 99久久久久国产精品免费 | re久久| 在线一区 | 国产精品美女久久久免费 | 丁香久久 | 免费精品国产 | 秋霞a级毛片在线看 | 精品视频一区二区三区在线观看 | 国产欧美一区二区在线观看 | 国产精品久久久久久久久免费高清 | 91精品国产91久久久久久最新 | 久久中文视频 | 欧美日韩精品综合 | 精品成人在线 | 日韩福利电影 | 久久国产精品72免费观看 | 亚洲一区在线观看视频 | 国产精品a级 | 国产成人久久av免费高清密臂 | 国产精品久久久爽爽爽麻豆色哟哟 | 酒色成人网 | 国产91网址| 国产精品小视频在线观看 | 看av网址 | 国产伊人精品 |