From 56a1e29cdddd21f22b0923679fc06ce350dcd602 Mon Sep 17 00:00:00 2001 From: shaw Date: Tue, 27 Jan 2026 09:16:34 +0800 Subject: [PATCH] =?UTF-8?q?fix(gateway):=20=E4=BF=AE=E5=A4=8D=20SSE=20?= =?UTF-8?q?=E6=B5=81=E5=BC=8F=E5=93=8D=E5=BA=94=20usage=20=E7=BB=9F?= =?UTF-8?q?=E8=AE=A1=E9=94=99=E8=AF=AF?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit message_delta 应完全覆盖 message_start 的 usage 数据, 而非仅在值为 0 时才更新。 --- backend/internal/service/gateway_service.go | 17 +++++------------ 1 file changed, 5 insertions(+), 12 deletions(-) diff --git a/backend/internal/service/gateway_service.go b/backend/internal/service/gateway_service.go index a8f5baeb..5819f15a 100644 --- a/backend/internal/service/gateway_service.go +++ b/backend/internal/service/gateway_service.go @@ -3372,19 +3372,12 @@ func (s *GatewayService) parseSSEUsage(data string, usage *ClaudeUsage) { } `json:"usage"` } if json.Unmarshal([]byte(data), &msgDelta) == nil && msgDelta.Type == "message_delta" { - // output_tokens 总是从 message_delta 获取 + // message_delta 是推理结束后的最终统计,应完全覆盖 message_start 的数据 + // 这对于 Claude API 和 GLM 等兼容 API 都是正确的行为 + usage.InputTokens = msgDelta.Usage.InputTokens usage.OutputTokens = msgDelta.Usage.OutputTokens - - // 如果 message_start 中没有值,则从 message_delta 获取(兼容GLM等API) - if usage.InputTokens == 0 { - usage.InputTokens = msgDelta.Usage.InputTokens - } - if usage.CacheCreationInputTokens == 0 { - usage.CacheCreationInputTokens = msgDelta.Usage.CacheCreationInputTokens - } - if usage.CacheReadInputTokens == 0 { - usage.CacheReadInputTokens = msgDelta.Usage.CacheReadInputTokens - } + usage.CacheCreationInputTokens = msgDelta.Usage.CacheCreationInputTokens + usage.CacheReadInputTokens = msgDelta.Usage.CacheReadInputTokens } }