すべてのプロダクト
Search
ドキュメントセンター

Alibaba Cloud Model Studio:メッセージ

最終更新日:Oct 15, 2025

このトピックでは、Assistant API の Message クラスについて説明し、メッセージの作成、一覧表示、取得、および変更方法について説明します。

関数名

種類

create

メッセージクラスを作成します。

retrieve

メッセージクラスを取得します。

modify

メッセージクラスを変更します。

list

メッセージクラスを一覧表示します。

メッセージを作成する

HTTP

サンプルコード

curl --location 'https://dashscope-intl.aliyuncs.com/api/v1/threads/thread_e99a9fe7-0433-426f-98ad-a5139c36579c/messages' \
--header 'Content-Type: application/json' \
--header "Authorization: Bearer $DASHSCOPE_API_KEY" \
--data '{
    "role": "user",
    "content": "Who are you",
    "metadata": {}
}'

リクエストパラメーター

パラメーター

説明

タイプ

必須

thread id

メッセージが渡されるスレッドの ID。

str

はい

content

メッセージの詳細。

str

はい

role

メッセージのロール。 user のみがサポートされています。

str

いいえ

metadata

その他の関連情報。

str

いいえ

サンプルレスポンス

{
    "id": "message_f1933671-19e1-4162-ad25-7326165123e1",
    "object": "thread.message",
    "created_at": 1711508433283,
    "thread_id": "thread_e99a9fe7-0433-426f-98ad-a5139c36579c",
    "assistant_id": "",
    "run_id": "",
    "role": "user",
    "content": [
        {
            "type": "text",
            "text": {
                "value": "Who are you",
                "annotations": []
            }
        }
    ],
    "metadata": {},
    "from": "",
    "name": "",
    "plugin_call": {},
    "tool_calls": [],
    "status": {},
    "request_id": "b3ad40b9-f052-9665-a064-dab11c34625f"
}

レスポンスパラメーター

出力はメッセージオブジェクトで、入力パラメーターに加えて次のフィールドが含まれています。

  • id: メッセージ ID。

  • request_id: リクエスト ID。

SDK

サンプルコード

from dashscope import Messages
import dashscope
import os

dashscope.base_http_api_url = 'https://dashscope-intl.aliyuncs.com/api/v1'
msg = Messages.create(
    'the_thread_id',
    # 環境変数を最初に設定することをお勧めします。環境変数を設定していない場合は、次の行を Model Studio API キーに置き換えます: api_key="sk-xxx"
    api_key=os.getenv("DASHSCOPE_API_KEY"),
    content='The message content.',
    role='user',
    metadata={'key': 'value'}
)
import com.alibaba.dashscope.exception.ApiException;
import com.alibaba.dashscope.exception.InputRequiredException;
import com.alibaba.dashscope.exception.InvalidateParameter;
import com.alibaba.dashscope.exception.NoApiKeyException;
import com.alibaba.dashscope.threads.messages.Messages;
import com.alibaba.dashscope.threads.messages.TextMessageParam;
import com.alibaba.dashscope.threads.messages.ThreadMessage;
import com.alibaba.dashscope.utils.Constants;

public class Main {
    static {
        Constants.baseHttpApiUrl="https://dashscope-intl.aliyuncs.com/api/v1";
    }
    public static void main(String[] args) throws ApiException, NoApiKeyException, InputRequiredException, InvalidateParameter, InterruptedException {
        // スレッドへのメッセージを作成する
        Messages messages = new Messages();
        TextMessageParam param = TextMessageParam.builder()
                // 環境変数を最初に設定することをお勧めします。環境変数を設定していない場合は、次の行を Model Studio API キーに置き換えます: apiKey("sk-xxx")
                .apiKey(System.getenv("DASHSCOPE_API_KEY"))
                .role("user")
                .content("How to make delicious beef and potato stew?")
                .build();
        ThreadMessage message = messages.create("threadId", param);
    }
}

リクエストパラメーター

パラメーター

タイプ

デフォルト値

説明

thread_id

str

-

スレッド ID。

content

str

-

メッセージの内容。

role

str

'user'

メッセージのロール。デフォルト値は user です。

metadata

Dict

なし

メッセージに関連付けられたキーと値の情報。

workspace

str

なし

Model Studio のワークスペース ID。このパラメーターは、api_key がサブワークスペース API キーの場合にのみ必須です。

api_key

str

なし

Model Studio のAPI キーです。 API キーを環境変数として設定することを推奨します。

サンプルレスポンス

結果はメッセージオブジェクトです。以下のコードは、内容を JSON フォーマットで示しています。

{
    "assistant_id": "",
    "content": [
        {
            "text": {
                "value": "sdhafjdasf"
            },
            "type": "text"
        }
    ],
    "created_at": 1711345341301,
    "display": true,
    "from": "",
    "gmt_crete": "2024-03-25 13:42:21",
    "gmt_update": "2024-03-25 13:42:21",
    "id": "message_05494921-a646-484e-85fc-76329acba842",
    "metadata": {
        "key": "value"
    },
    "name": "",
    "object": "thread.message",
    "plugin_call": {},
    "request_id": "631de0b3-7e50-9c9e-8444-0924d1b7e7a5",
    "role": "user",
    "run_id": "",
    "status": {},
    "status_code": 200,
    "thread_id": "thread_f1e7737e-b045-479f-99d1-510db49d535b",
    "tool_calls": []
}

レスポンスパラメーター

パラメーター

タイプ

説明

status_code

int

HTTP ステータスコード。値 200 は、呼び出しが成功したことを示します。その他の値は、呼び出しが失敗したことを示します。

id

str

メッセージ ID。UUID 文字列です。

content

List[dict]

メッセージの内容。

content.type

str

コンテンツタイプ。例: text。

content.text

dict

コンテンツ。

content.text.value

str

コンテンツのテキスト値。

metadata

Dict

このメッセージに関連付けられているキーと値の情報。

tool_calls

Dict

ツール呼び出しに関する情報。

plugin_call

Dict

プラグイン呼び出しに関する情報。

created_at

タイムスタンプ

アシスタントが作成された時刻。

gmt_created

datetime

2024-03-22 17:12:31

gmt_modified

datetime

2024-03-22 17:12:31

code

str

リクエストが失敗したことを示します。このパラメーターはエラーコードを示します。リクエストが成功した場合は、このパラメーターは無視されます。

Python SDK の場合のみ返されます。

message

str

リクエストが失敗したことを示します。このパラメーターは、失敗の詳細を示します。リクエストが成功した場合は、このパラメーターは無視されます。

Python SDK の場合のみ返されます。

メッセージを一覧表示する

HTTP

サンプルコード

curl --location 'https://dashscope-intl.aliyuncs.com/api/v1/threads/thread_e99a9fe7-0433-426f-98ad-a5139c36579c/messages?limit=2&order=desc' \
--header 'Content-Type: application/json' \
--header "Authorization: Bearer $DASHSCOPE_API_KEY"

リクエストパラメーター

パラメーター

説明

タイプ

必須

thread id

メッセージが渡されるスレッドの ID。

str

はい

limit

返すメッセージの数。

int

いいえ

order

メッセージが作成時刻でソートされる順序。昇順または降順を指定できます。

str

いいえ (デフォルト値は "desc")

サンプルレスポンス

{
    "object": "list",
    "data": [
        {
            "id": "message_f1933671-19e1-4162-ad25-7326165123e1",
            "object": "thread.message",
            "created_at": 1711508433283,
            "thread_id": "thread_e99a9fe7-0433-426f-98ad-a5139c36579c",
            "assistant_id": "",
            "run_id": "",
            "role": "user",
            "content": [
                {
                    "type": "text",
                    "text": {
                        "value": "Who are you",
                        "annotations": []
                    }
                }
            ],
            "metadata": {},
            "from": "",
            "name": "",
            "plugin_call": {},
            "tool_calls": [],
            "status": {}
        }
    ],
    "first_id": "message_f1933671-19e1-4162-ad25-7326165123e1",
    "last_id": "message_f1933671-19e1-4162-ad25-7326165123e1",
    "has_more": false,
    "request_id": "78f7d607-4a9a-90c6-8040-d3f81c84d60a"
}

レスポンスパラメーター

出力はメッセージオブジェクトのリストで、ユーザー入力パラメーターに加えて追加のフィールドが含まれています。

  • 複数のメッセージのリスト。

SDK

サンプルコード

from dashscope import Messages
import dashscope
import os

dashscope.base_http_api_url = 'https://dashscope-intl.aliyuncs.com/api/v1'

messages = Messages.list(
    'thread_id',
    # 環境変数を最初に設定することをお勧めします。環境変数を設定していない場合は、次の行を Model Studio API キーに置き換えます: api_key="sk-xxx"
    api_key=os.getenv("DASHSCOPE_API_KEY"),
    limit=1,
    order='desc'
)
import com.alibaba.dashscope.common.GeneralListParam;
import com.alibaba.dashscope.common.ListResult;
import com.alibaba.dashscope.exception.ApiException;
import com.alibaba.dashscope.exception.InputRequiredException;
import com.alibaba.dashscope.exception.InvalidateParameter;
import com.alibaba.dashscope.exception.NoApiKeyException;
import com.alibaba.dashscope.threads.messages.Messages;
import com.alibaba.dashscope.threads.messages.ThreadMessage;
import com.alibaba.dashscope.utils.Constants;

public class Main {
    static {
        Constants.baseHttpApiUrl="https://dashscope-intl.aliyuncs.com/api/v1";
    }
    public static void main(String[] args) throws ApiException, NoApiKeyException, InputRequiredException, InvalidateParameter, InterruptedException {
        Messages messages = new Messages();
        // 環境変数を最初に設定することをお勧めします。環境変数を設定していない場合は、次の行を Model Studio API キーに置き換えます: apiKey("sk-xxx")
        GeneralListParam listThreadMessages = GeneralListParam.builder()
                .apiKey(System.getenv("DASHSCOPE_API_KEY"))
                .build();
        ListResult<ThreadMessage> message = messages.list("threadId", listThreadMessages);
    }
}

リクエストパラメーター

パラメーター

タイプ

デフォルト値

説明

thread_id

str

-

クエリするスレッドの ID。

limit

int

なし

取得するメッセージの数。

order

str

なし

created_at でメッセージをソートする順序。

workspace

str

なし

Model Studio のワークスペース ID。このパラメーターは、api_key がサブワークスペース API キーの場合にのみ必須です。

api_key

str

なし

Model Studio のAPI キーAPI キーを環境変数として設定することをお勧めします。

レスポンスパラメーター

パラメーター

タイプ

説明

has_more

bool

取得するメッセージがさらに存在するかどうかを示します。

last_id

str

返されたリストの最後のメッセージの ID。

first_id

str

返されたリストの最初のメッセージの ID。

data

list[Message]

メッセージオブジェクトのリスト。

メッセージを取得する

HTTP

サンプルコード

curl --location 'https://dashscope-intl.aliyuncs.com/api/v1/threads/thread_e99a9fe7-0433-426f-98ad-a5139c36579c/messages/message_ea26d29d-4509-490e-98e9-9f6238bd821b' \
--header 'Content-Type: application/json' \
--header "Authorization: Bearer $DASHSCOPE_API_KEY"

リクエストパラメーター

パラメーター

説明

タイプ

必須

thread id

取得するメッセージが渡されるスレッドの ID。

str

はい

message_id

取得するメッセージの ID。

str

はい

サンプルレスポンス

{
    "id": "message_ea26d29d-4509-490e-98e9-9f6238bd821b",
    "object": "thread.message",
    "created_at": 1711508622598,
    "thread_id": "thread_e99a9fe7-0433-426f-98ad-a5139c36579c",
    "assistant_id": "",
    "run_id": "",
    "role": "user",
    "content": [
        {
            "type": "text",
            "text": {
                "value": "Hello",
                "annotations": []
            }
        }
    ],
    "metadata": {},
    "from": "",
    "name": "",
    "plugin_call": {},
    "tool_calls": [],
    "status": {},
    "request_id": "4d5ce962-91c3-9edb-87f7-00bbf985135e"
}

レスポンスパラメーター

出力は取得されたメッセージオブジェクトで、次のフィールドが含まれています。

  • id: message_id

  • request_id: リクエスト ID。

SDK

サンプルコード

from dashscope import Messages
import dashscope
import os

dashscope.base_http_api_url = 'https://dashscope-intl.aliyuncs.com/api/v1'

message = Messages.retrieve(
    'message_id',
    # 環境変数を最初に設定することをお勧めします。環境変数を設定していない場合は、次の行を Model Studio API キーに置き換えます: api_key="sk-xxx"
    api_key=os.getenv("DASHSCOPE_API_KEY"),
    thread_id='thread_id'
)
import com.alibaba.dashscope.exception.ApiException;
import com.alibaba.dashscope.exception.InputRequiredException;
import com.alibaba.dashscope.exception.InvalidateParameter;
import com.alibaba.dashscope.exception.NoApiKeyException;
import com.alibaba.dashscope.threads.messages.Messages;
import com.alibaba.dashscope.threads.messages.ThreadMessage;
import com.alibaba.dashscope.utils.Constants;

public class Main {
    static {
        Constants.baseHttpApiUrl="https://dashscope-intl.aliyuncs.com/api/v1";
    }
    public static void main(String[] args) throws ApiException, NoApiKeyException, InputRequiredException, InvalidateParameter, InterruptedException {
        Messages messages = new Messages();
        // 環境変数を最初に設定することをお勧めします。環境変数を設定していない場合は、次の行を Model Studio API キーに置き換えます: apiKey("sk-xxx")
        String apiKey = System.getenv("DASHSCOPE_API_KEY");
        ThreadMessage message = messages.retrieve("threadId", "messageId", apiKey);
    }
}

リクエストパラメーター

パラメーター

タイプ

デフォルト値

説明

message_id

str

-

クエリするメッセージの ID。

thread_id

str

-

クエリするメッセージが属するスレッドの ID。

workspace

str

なし

Model Studio のワークスペース ID。このパラメーターは、api_key がサブワークスペース API キーの場合にのみ必須です。

api_key

str

なし

Model Studio のAPI キーAPI キーを環境変数として設定することをお勧めします。

レスポンスパラメーター

create のレスポンスパラメーターを参照してください。

メッセージを変更する

HTTP

サンプルコード

curl --location 'https://dashscope-intl.aliyuncs.com/api/v1/threads/thread_e99a9fe7-0433-426f-98ad-a5139c36579c/messages/message_ea26d29d-4509-490e-98e9-9f6238bd821b' \
--header 'Content-Type: application/json' \
--header "Authorization: Bearer $DASHSCOPE_API_KEY" \
--data '{
    "metadata": {
        "modified": "true",
        "user": "abc123"
    }
}'

リクエストパラメーター

パラメーター

説明

タイプ

必須

thread_id

変更するスレッドの ID。

str

はい

message_id

変更するメッセージの ID。

str

はい

metadata

メタデータ。

dict

サンプルレスポンス

{
    "id": "message_ea26d29d-4509-490e-98e9-9f6238bd821b",
    "object": "thread.message",
    "created_at": 1711508622598,
    "thread_id": "thread_e99a9fe7-0433-426f-98ad-a5139c36579c",
    "assistant_id": "",
    "run_id": "",
    "role": "user",
    "content": [
        {
            "type": "text",
            "text": {
                "value": "Hello",
                "annotations": []
            }
        }
    ],
    "metadata": {
        "modified": "true",
        "user": "abc123"
    },
    "from": "",
    "name": "",
    "plugin_call": {},
    "tool_calls": [],
    "status": {},
    "request_id": "7877b011-cb94-9df1-9add-dc42b7d611f6"
}

レスポンスパラメーター

出力は変更されたメッセージオブジェクトで、入力パラメーターに加えて次のフィールドが含まれています。

  • id: メッセージ ID。

  • request_id: リクエスト ID。

SDK

サンプルコード

from dashscope import Messages
import dashscope
import os

dashscope.base_http_api_url = 'https://dashscope-intl.aliyuncs.com/api/v1'

thread = Messages.update(
    'message_id',
    # 環境変数を最初に設定することをお勧めします。環境変数を設定していない場合は、次の行を Model Studio API キーに置き換えます: api_key="sk-xxx"
    api_key=os.getenv("DASHSCOPE_API_KEY"),
    thread_id='the_message_thread_id',
    metadata={'key': 'value'}
)
import java.util.Collections;
import com.alibaba.dashscope.common.UpdateMetadataParam;
import com.alibaba.dashscope.exception.ApiException;
import com.alibaba.dashscope.exception.InputRequiredException;
import com.alibaba.dashscope.exception.InvalidateParameter;
import com.alibaba.dashscope.exception.NoApiKeyException;
import com.alibaba.dashscope.threads.messages.Messages;
import com.alibaba.dashscope.utils.Constants;

public class Main {
    static {
        Constants.baseHttpApiUrl="https://dashscope-intl.aliyuncs.com/api/v1";
    }
    public static void main(String[] args) throws ApiException, NoApiKeyException, InputRequiredException, InvalidateParameter, InterruptedException {
        Messages messages = new Messages();
        // 環境変数を最初に設定することをお勧めします。環境変数を設定していない場合は、次の行を Model Studio API キーに置き換えます: apiKey("sk-xxx")
        UpdateMetadataParam updateMetadataParam = UpdateMetadataParam.builder()
                .metadata(Collections.singletonMap("key", "value"))
                .apiKey(System.getenv("DASHSCOPE_API_KEY"))
                .build();
        messages.update("thread_id", "message_Id", updateMetadataParam);
    }
}

リクエストパラメーター

パラメーター

タイプ

デフォルト値

説明

message_id

str

-

更新するメッセージの ID。

thread_id

str

-

更新するメッセージが属するスレッドの ID。

metadata

Dict

なし

スレッドに関連付けられた情報。

workspace

str

なし

Model Studio の ワークスペース ID。 このパラメーターは、api_key がサブワークスペース API キーの場合にのみ必須です。

api_key

str

なし

Model Studio の API キーAPI キーを環境変数として設定することをお勧めします。

レスポンスパラメーター

create のレスポンスパラメーターを参照してください。

エラーコード

呼び出しが失敗してエラーメッセージが返された場合は、トラブルシューティングのためにエラーメッセージを参照してください。