DeepSeek V4 + Claude Code thinking mode 400 错误修复方案

DeepSeek V4 + Claude Code thinking mode 400 错误修复方案

DeepSeek V4 + Claude Code thinking mode 400 错误修复方案

问题描述

使用 DeepSeek V4 Pro / V4 Flash 的 thinking mode + tool calls 时,第一轮工具调用后的每次请求都返回 400 错误:

复制代码

API Error: 400 The content[].thinking in the thinking mode must be passed back to the API.

根因

复制代码

Claude Code → DeepSeek API(返回 reasoning_content / thinking 块)

Claude Code 保存对话历史时丢弃非标准的 thinking 字段

下一轮请求 → DeepSeek API:检测到 assistant 消息缺少 thinking 块 → 400

DeepSeek V4 要求 multi-turn 对话中,每个 role: assistant 的消息必须保留 thinking 块。Claude Code / cc-switch 在序列化历史时把它丢弃了。

解决方案

在 Claude Code 和 DeepSeek API 之间插入一个本地 Node.js 代理,自动补全被丢弃的 thinking 字段。

拓扑

复制代码

Claude Code → cc-switch → 本地代理 (127.0.0.1:15722) → api.deepseek.com

注入 thinking 块

步骤

  1. 创建代理脚本 ds-proxy.js
    js
    复制代码
    const http = require('http');
    const { Readable } = require('stream');

const DEEPSEEK_BASE = 'https://api.deepseek.com';

const PORT = 15722;

function fixMessages(data) {

if (!data.messages && !Array.isArray(data.messages)) return;

for (const msg of data.messages) {

if (msg.role !== 'assistant') continue;

if (Array.isArray(msg.content)) {

const hasThinking = msg.content.some(b => b.type === 'thinking');

if (!hasThinking) {

msg.content.unshift({ type: 'thinking', thinking: '' });

}

} else {

msg.reasoning_content = msg.reasoning_content || '';

}

}

}

const server = http.createServer(async (req, res) => {

console.log(${req.method} ${req.url});

res.setHeader('Access-Control-Allow-Origin', '*');

复制代码
if (req.method === 'OPTIONS') {
    res.writeHead(204);
    res.end();
    return;
}

if (req.method === 'GET') {
    res.writeHead(200, { 'Content-Type': 'application/json' });
    res.end(JSON.stringify({ id: 'root', object: 'list' }));
    return;
}

if (req.method !== 'POST') {
    res.writeHead(404);
    res.end('Not Found');
    return;
}

let body = '';
req.on('data', chunk => body += chunk);
req.on('end', async () => {
    try {
        const data = JSON.parse(body);
        fixMessages(data);

        const target = DEEPSEEK_BASE + req.url;
        console.log('->', target);

        const apiRes = await fetch(target, {
            method: 'POST',
            headers: {
                'Content-Type': 'application/json',
                'Authorization': req.headers.authorization,
                'anthropic-version': req.headers['anthropic-version'] || ''
            },
            body: JSON.stringify(data)
        });

        console.log('<-', apiRes.status);
        const headers = {};
        apiRes.headers.forEach((v, k) => { headers[k] = v; });
        res.writeHead(apiRes.status, headers);

        if (apiRes.body) {
            Readable.fromWeb(apiRes.body).pipe(res);
        } else {
            res.end();
        }
    } catch (err) {
        console.error('Proxy error:', err.message);
        res.writeHead(500);
        res.end(JSON.stringify({ error: 'Proxy Error: ' + err.message }));
    }
});

});

server.listen(PORT, () => {

console.log('DS4 Proxy on http://127.0.0.1:' + PORT);

});

  1. 启动代理

powershell

复制代码

node ds-proxy.js

保持在后台运行。

  1. 配置 cc-switch
    DeepSeek provider 的 Base URL 设为:

复制代码

http://127.0.0.1:15722/anthropic

或跳过 cc-switch,直连代理:

powershell

复制代码

$env:ANTHROPIC_BASE_URL = "http://127.0.0.1:15722/anthropic"

$env:ANTHROPIC_API_KEY = "你的DeepSeek API Key"

claude

  1. 重启 Claude Code

代理处理逻辑

场景 操作

Anthropic 格式(content 为数组) 在 content 最前面插入 {type:"thinking",thinking:""}

OpenAI 格式 注入 reasoning_content: ""

连通性检测(GET) 返回 {"id":"root","object":"list"} 模拟 API

相关推荐
这token有力气44 分钟前
Function Calling 格式漂移
人工智能
onething3651 小时前
Spring Boot + Spring AI 从入门到实战:7天转型计划 Day 5 —— SSE 流式输出 + 打字机效果
人工智能·后端·全栈
onething3651 小时前
Spring Boot + Spring AI 从入门到实战:7天转型计划 Day 6 —— 业务完善 + 会话消息预览
人工智能·后端·全栈
IT_陈寒2 小时前
SpringBoot自动配置的坑,我爬了三天才出来
前端·人工智能·后端
甲维斯3 小时前
笑抽了!DeepSeek识图,豆包完胜了!
人工智能·deepseek
Lei活在当下11 小时前
【AI手记系列-2026/6/18】iSparto & Harness,Caveman 以及AI时代的生存指南
人工智能·llm·openai
冬奇Lab13 小时前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLite
数据库·人工智能·llm
冬奇Lab13 小时前
Agent 系列(22):Context Engineering 深度——三种上下文管理策略的量化对比
人工智能·agent
hboot13 小时前
AI工程师第二课 - 数据处理
人工智能·python·数据分析
程序员cxuan13 小时前
DeepSeek 杀入多模态,识图功能正式上线!
人工智能·后端·程序员