本指南說明如何呼叫 Google Chat API 的
messages.create()
敬上
方法執行下列任一操作:
- 傳送內含文字、資訊卡和互動式小工具的訊息,
- 傳送私人訊息給特定的 Chat 使用者。
- 發起或回覆訊息串。
- 為訊息命名,方便你在其他 Chat API 中指定 要求。
訊息大小上限 (包括任何文字或資訊卡) 為 32,000 個位元組。 如要傳送超過此大小的訊息,你的 Chat 應用程式 就必須傳送多則訊息。
除了呼叫 messages.create()
方法外,即時通訊應用程式
您可以建立並傳送訊息,回覆使用者互動,例如張貼
當使用者將 Chat 應用程式新增到
空白鍵。回覆互動時,即時通訊應用程式可以使用其他
多種訊息功能,包括互動式對話方塊和連結預覽
存取 API為了回覆使用者,Chat 應用程式會傳回
讀取訊息,不必呼叫 Chat API。學習
瞭解如何傳送訊息以回覆互動,請參閱
接收及回覆與 Google Chat 應用程式的互動。
Chat 如何顯示和屬性使用 Chat API 建立的訊息
您可以使用以下項目呼叫 messages.create()
方法:
應用程式驗證
和使用者驗證。
Chat 會以不同方式區分訊息傳送者
取決於您使用的驗證類型。
當您以 Chat 應用程式的身分進行驗證時 Chat 應用程式會傳送訊息。
當您以使用者的身分進行驗證後,Chat 應用程式會將 傳送留言Chat 也會將 顯示訊息名稱的即時通訊應用程式。
驗證類型也會決定哪些訊息功能和介面 請附加在訊息中透過應用程式驗證功能 Chat 擴充應用程式可以傳送含有 RTF 格式的訊息, 卡片式介面和互動式小工具。 由於 Chat 使用者只能在訊息中傳送簡訊,您可以 僅在使用使用者驗證機制建立訊息時,才含有文字。 進一步瞭解訊息功能 如要瞭解 Chat API 可用的功能,請參閱 Google Chat 訊息總覽。
本指南說明如何使用其中一種驗證類型傳送訊息 快速分享
必要條件
Node.js
- 企業或企業 具有存取權的 Google Workspace 帳戶 Google Chat。
- 設定環境:
- 建立 Google Cloud 專案。
- 設定 OAuth 同意畫面。
- 啟用並設定 Google Chat API。 圖示和說明
- 安裝 Node.js Cloud 用戶端程式庫。
- 根據您要在 Google Chat API 中驗證的方式建立存取憑證
要求:
- 如要以 Chat 使用者的身分進行驗證,
建立 OAuth 用戶端 ID
憑證,並將憑證儲存為 JSON 檔案
client_secrets.json
至本機目錄。 - 如要以 Chat 應用程式的身分進行驗證,
建立服務帳戶
憑證,並將憑證儲存為 JSON 檔案
credentials.json
。
- 如要以 Chat 使用者的身分進行驗證,
建立 OAuth 用戶端 ID
憑證,並將憑證儲存為 JSON 檔案
- 根據你要以使用者或使用者身分驗證選擇授權範圍 Chat 應用程式。
- 通過驗證的 Google Chat 聊天室 撥打的即時通訊應用程式為成員。如要以 即時通訊應用程式,新增 Chat 擴充應用程式至聊天室。
Python
- 企業或企業 具有存取權的 Google Workspace 帳戶 Google Chat。
- 設定環境:
- 建立 Google Cloud 專案。
- 設定 OAuth 同意畫面。
- 啟用並設定 Google Chat API。 圖示和說明
- 安裝 Python Cloud 用戶端程式庫。
- 根據您要在 Google Chat API 中驗證的方式建立存取憑證
要求:
- 如要以 Chat 使用者的身分進行驗證,
建立 OAuth 用戶端 ID
憑證,並將憑證儲存為 JSON 檔案
client_secrets.json
至本機目錄。 - 如要以 Chat 應用程式的身分進行驗證,
建立服務帳戶
憑證,並將憑證儲存為 JSON 檔案
credentials.json
。
- 如要以 Chat 使用者的身分進行驗證,
建立 OAuth 用戶端 ID
憑證,並將憑證儲存為 JSON 檔案
- 根據你要以使用者或使用者身分驗證選擇授權範圍 Chat 應用程式。
- 通過驗證的 Google Chat 聊天室 撥打的即時通訊應用程式為成員。如要以 即時通訊應用程式,新增 Chat 擴充應用程式至聊天室。
Java
- 企業或企業 具有存取權的 Google Workspace 帳戶 Google Chat。
- 設定環境:
- 建立 Google Cloud 專案。
- 設定 OAuth 同意畫面。
- 啟用並設定 Google Chat API。 圖示和說明
- 安裝 Java Cloud 用戶端程式庫。
- 根據您要在 Google Chat API 中驗證的方式建立存取憑證
要求:
- 如要以 Chat 使用者的身分進行驗證,
建立 OAuth 用戶端 ID
憑證,並將憑證儲存為 JSON 檔案
client_secrets.json
至本機目錄。 - 如要以 Chat 應用程式的身分進行驗證,
建立服務帳戶
憑證,並將憑證儲存為 JSON 檔案
credentials.json
。
- 如要以 Chat 使用者的身分進行驗證,
建立 OAuth 用戶端 ID
憑證,並將憑證儲存為 JSON 檔案
- 根據你要以使用者或使用者身分驗證選擇授權範圍 Chat 應用程式。
- 通過驗證的 Google Chat 聊天室 撥打的即時通訊應用程式為成員。如要以 即時通訊應用程式,新增 Chat 擴充應用程式至聊天室。
Apps Script
- 企業或企業 具有存取權的 Google Workspace 帳戶 Google Chat。
- 設定環境:
- 建立 Google Cloud 專案。
- 設定 OAuth 同意畫面。
- 啟用並設定 Google Chat API。 圖示和說明
- 建立獨立的 Apps Script 專案, 並開啟 進階 Chat 服務。
- 在本指南中,您必須使用 user 或應用程式驗證如要以 Chat 應用程式的形式進行驗證,請建立 自己的服務帳戶憑證詳細步驟請參閱 以 Google Chat 應用程式。
- 根據你要以使用者或使用者身分驗證選擇授權範圍 Chat 應用程式。
- 通過驗證的 Google Chat 聊天室 撥打的即時通訊應用程式為成員。如要以 即時通訊應用程式,新增 Chat 擴充應用程式至聊天室。
以 Chat 應用程式的形式傳送訊息
本節說明如何傳送內含文字、資訊卡和 互動式配件小工具 應用程式驗證。
如要使用應用程式驗證功能呼叫 messages.create()
,您必須指定
要求中填入下列欄位:
chat.bot
授權範圍。- 在其中的
Space
資源 這則訊息的效期。Chat 應用程式必須是 聊天室成員。 Message
要建立的資源如要定義訊息內容,您可以加上 RTF 格式 (text
)、 一或多個資訊卡介面 (cardsV2
), 或兩者並行
您也可以選擇加入下列資訊:
- 要包含的
accessoryWidgets
欄位 訊息底部的互動式按鈕。 - 要填入的
privateMessageViewer
欄位 傳送私人訊息給指定使用者。 messageId
欄位:可讓您 命名訊息,以便在其他 API 要求中使用。thread.threadKey
和messageReplyOption
欄位 發起或回覆討論串。如果聊天室沒有 但系統會忽略這個欄位。
以下程式碼示範如何使用 Chat 應用程式 能傳送含有以下內容的訊息: 訊息底部顯示文字、資訊卡以及可點選的按鈕:
Node.js
Python
Java
Apps Script
如要執行這個範例,請將 SPACE_NAME
替換為
聊天室的
name
欄位中傳回的資料。
您可以呼叫
spaces.list()
方法
或從聊天室網址複製
在訊息底部新增互動式小工具
在本指南的第一個程式碼範例中 Chat 應用程式訊息的 (稱為配件小工具)。配件小工具 顯示在訊息中的任何文字或資訊卡後方。使用這些小工具 使用者可以透過多種方式與訊息互動,包括:
- 為訊息的準確度或滿意度評分。
- 回報與訊息或 Chat 應用程式相關的問題。
- 開啟相關內容的連結,例如說明文件。
- 關閉或延後 Chat 應用程式中的類似訊息 一段時間。
如要新增配件小工具,請在
accessoryWidgets[]
敬上
] 欄位,然後指定一或多個小工具
。
下圖顯示會附加的 Chat 應用程式 附有配件小工具的文字訊息,可讓使用者為自己的體驗評分 取得最新資訊
以下範例顯示會建立簡訊的要求主體
兩個配件按鈕使用者點選按鈕時,
函式 (例如 doUpvote
) 會處理互動:
{
text: "Rate your experience with this Chat app.",
accessoryWidgets: [{ buttonList: { buttons: [{
icon: { material_icon: {
name: "thumb_up"
}},
color: { red: 0, blue: 255, green: 0 },
onClick: { action: {
function: "doUpvote"
}}
}, {
icon: { material_icon: {
name: "thumb_down"
}},
color: { red: 0, blue: 255, green: 0 },
onClick: { action: {
function: "doDownvote"
}}
}]}}]
}
傳送私人訊息
即時通訊應用程式可以在私人訊息中傳送訊息, 只有聊天室中的特定使用者看得到訊息。如果 Chat 應用程式會傳送私人訊息,也就是訊息 會顯示標籤,告知使用者該訊息僅供檢視。
如要使用 Chat API 傳送私人訊息,請指定
privateMessageViewer
敬上
] 欄位的值。如要指定使用者,請將值設為
所需的 User
資源
代表 Chat 使用者。您也可以使用
name
欄位,
User
資源,如以下範例所示:
{
text: "Hello private world!",
privateMessageViewer: {
name: "users/USER_ID"
}
}
如要使用此範例,請將 USER_ID
或使用者專屬 ID,例如 12345678987654321
或
hao@cymbalgroup.com
。如要進一步瞭解如何指定使用者,請參閱
識別並指定 Google Chat 使用者。
如要傳送私人訊息,必須在要求中省略以下內容:
代表使用者傳送簡訊
本節說明如何使用 使用者驗證。 採用使用者驗證功能時,郵件內容只能包含文字 而且如果訊息功能僅支援特定用途 即時通訊應用程式,包括資訊卡介面和互動式小工具。
如要透過使用者驗證機制呼叫 messages.create()
,您必須指定
要求中填入下列欄位:
- 授權範圍
。下列範例使用
chat.messages.create
範圍。 - 在其中的
Space
資源 這則訊息的效期。已驗證使用者必須是 空白鍵。 Message
要建立的資源如要定義訊息內容,您必須將text
敬上 ] 欄位。
您也可以選擇加入下列資訊:
messageId
欄位:可讓您 命名訊息,以便在其他 API 要求中使用。thread.threadKey
和messageReplyOption
欄位 發起或回覆討論串。如果聊天室沒有 但系統會忽略這個欄位。
以下程式碼示範如何使用 Chat 應用程式 可以代表通過驗證的使用者在指定聊天室中傳送簡訊:
Node.js
Python
Java
Apps Script
如要執行這個範例,請將 SPACE_NAME
替換為
聊天室的
name
] 欄位。您可以呼叫
spaces.list()
方法
或從聊天室網址複製
在討論串中發起或回覆
針對使用執行緒的聊天室, 您可以指定新訊息是發起討論串,或是回覆 或現有討論串
根據預設,您使用 Chat API 建立的訊息會啟動新的 。為了方便辨識及回覆討論串,可以指定 加入執行緒金鑰:
- 在要求內文中,指定
thread.threadKey
敬上 ] 欄位。 - 指定查詢參數
messageReplyOption
敬上 來判斷如果鍵已存在,會發生什麼情況。
如何建立回覆現有討論串的訊息:
- 在要求主體中,納入
thread
欄位。如果已經設定 請指定threadKey
敬上 每個專案的名稱否則,您必須使用name
敬上 執行緒之間的關係。 - 指定查詢參數
messageReplyOption
。
以下程式碼示範如何使用 Chat 應用程式 可以傳送文字訊息,或回覆系統識別出的討論串 每個空間的金鑰:
Node.js
Python
Java
Apps Script
如要執行這個範例,請替換下列內容:
THREAD_KEY
:聊天室中現有的執行緒金鑰,或 建立新的執行緒,為討論串命名。SPACE_NAME
:聊天室的 IDname
] 欄位。您可以呼叫spaces.list()
方法 或從聊天室網址複製
輸入訊息名稱
如要在日後的 API 呼叫中擷取或指定訊息,您可以為訊息命名
只要在 messages.create()
要求中設定 messageId
欄位即可。
為訊息命名後,您不需要儲存
系統從訊息資源名稱中指派的 ID (如
name
敬上
] 欄位)。
舉例來說,如要使用 get()
方法擷取訊息,您可以使用
指定要擷取哪些訊息的資源名稱。資源名稱是
格式為 spaces/{space}/messages/{message}
,其中 {message}
代表
您在建立 Deployment 時
撰寫新的電子郵件訊息
如要為訊息命名,請在
messageId
敬上
] 欄位輸入訊息內容。messageId
欄位會設定
clientAssignedMessageId
擁有多個欄位,Message
)。
你只能在建立訊息時命名訊息。您無法為或 修改現有郵件的自訂 ID。自訂 ID 必須符合下列規定 規定:
- 開頭為
client-
。舉例來說,client-custom-name
是有效的自訂值 ID,但custom-name
不是。 - 長度上限為 63 個半形字元,且只能使用小寫英文字母、數字和 連字號
- 聊天室中不得重複,Chat 應用程式無法使用 以便為不同訊息套用相同的自訂 ID。
以下程式碼示範如何使用 Chat 應用程式 可以代表 已驗證使用者:
Node.js
Python
Java
Apps Script
如要執行這個範例,請替換下列內容:
SPACE_NAME
:聊天室的 IDname
] 欄位。您可以呼叫spaces.list()
方法 或從聊天室網址複製MESSAGE-ID
:開頭訊息的名稱custom-
。不得與 指定聊天室中的即時通訊應用程式。
疑難排解
Google Chat 應用程式或 card 會傳回錯誤, 即時通訊介面顯示「發生錯誤」的訊息。 或「無法處理你的要求」。有時使用 Chat UI 不會顯示任何錯誤訊息,但 Chat 應用程式或 資訊卡產生非預期的結果例如資訊卡訊息 顯示。
雖然 Chat UI 中可能不會顯示錯誤訊息, 提供描述性錯誤訊息和記錄資料,協助您修正錯誤 。如需觀看說明, 偵錯及修正錯誤,請參閱 疑難排解並修正 Google Chat 錯誤。
相關主題
- 使用卡片建立工具 設計及預覽 Chat 應用程式的 JSON 資訊卡訊息。
- 設定郵件格式。
- 取得訊息的詳細資料。
- 列出聊天室中的訊息。
- 更新訊息。
- 刪除訊息。
- 找出 Google Chat 訊息中的使用者。
- 使用連入 Webhook 傳送訊息至 Google Chat。