Claude Code Buddy 修改指南:如何获得闪光传说级宠物

4/2/2026
5 min read

Claude Code Buddy 修改指南:如何获得闪光传说级宠物

2026年4月1日,Anthropic 在 Claude Code 2.1.89 版本中悄然上线了一个彩蛋功能——/buddy 宠物系统。在终端输入 /buddy 后,一只 ASCII 风格的小动物会"孵化"在你的输入框旁边,陪你写代码、吐槽 bug。

每只 Buddy 由账号 ID 通过确定性算法生成,意味着同一个账号永远获得同一只宠物。但通过修改配置文件中的 userID,我们可以"重ROLL"出心仪的宠物。本文将详细介绍算法原理和完整的修改脚本。

一、Buddy 系统概览

18 种物种

系统目前包含 18 种可爱的物种:

  • duck - 鸭子(经典的 Rubber Duck Debugging)

  • goose - 鹅(调皮捣蛋)

  • blob - 果冻(软萌不定形)

  • cat - 猫(高冷傲娇)

  • dragon - 龙(霸气守护)

  • octopus - 章鱼(多线程思考)

  • owl - 猫头鹰(智慧导师)

  • penguin - 企鹅(正装出席)

  • turtle - 乌龟(稳健可靠)

  • snail - 蜗牛(慢工出细活)

  • ghost - 幽灵(神出鬼没)

  • axolotl - 蝾螈(可爱治愈)

  • capybara - 水豚(佛系大师)

  • cactus - 仙人掌(暖心植物)

  • robot - 机器人(理性至上)

  • rabbit - 兔子(活蹦乱跳)

  • mushroom - 蘑菇(安静观察)

  • chonk - 胖墩(圆滚滚)

5 级稀有度

  • Common(普通) - 60% 概率,无帽子装饰

  • Uncommon(罕见) - 25% 概率,解锁帽子

  • Rare(稀有) - 10% 概率,更多装饰

  • Epic(史诗) - 4% 概率,专属装饰

  • Legendary(传说) - 1% 概率,顶级装饰
此外还有独立的 1% 闪光(Shiny)概率,闪光宠物拥有彩虹色微光动画!闪光传说的概率是 1% × 1% = 0.01%,约万分之一。

二、算法原理深度解析

Buddy 的生成采用确定性随机算法,核心流程如下:

1. 种子字符串拼接

const SALT = "friend-2026-401"; // 4月1日愚人节彩蛋 const key = userId + SALT;

Salt 值 friend-2026-401 中的 401 代表 4月1日——一个精心设计的愚人节彩蛋。

2. FNV-1a 32-bit 哈希

将种子字符串转换为 32 位整数:

function hashString(s) { let h = 2166136261; // FNV offset basis for (let i = 0; i < s.length; i++) { h ^= s.charCodeAt(i); h = Math.imul(h, 16777619); // FNV prime } return h >>> 0; }

3. Mulberry32 PRNG

用哈希值初始化伪随机数生成器:function mulberry32(seed) { let a = seed >>> 0; return function() { a |= 0; a = (a + 0x6d2b79f5) | 0; let t = Math.imul(a ^ (a >>> 15), 1 | a); t = (t + Math.imul(t ^ (t >>> 7), 61 | t)) ^ t; return ((t ^ (t >>> 14)) >>> 0) / 4294967296; }; }

Мульберри32 — это легковесный генератор псевдослучайных чисел (PRNG), часто используемый в разработке игр, подходящий для программной генерации и таблиц выпадения лута.

4. Извлечение редкости (ключевое!)

const RARITIES = ["common", "uncommon", "rare", "epic", "legendary"]; const RARITYWEIGHTS = { common: 60, uncommon: 25, rare: 10, epic: 4, legendary: 1 };

function rollRarity(rng) { const total = 60 + 25 + 10 + 4 + 1; // = 100 let roll = rng() total; for (const rarity of RARITIES) { roll -= RARITYWEIGHTS[rarity]; if (roll < 0) return rarity; } return "common"; }

重要:RARITIES 数组的顺序必须是从低到高,这是加权随机选择的标准实现。

三、完整 Reroll 脚本

以下脚本可以搜索并生成闪光传说级 Buddy 的 userID:

// Claude Code Buddy Reroll 脚本 // 基于 Claude Code 源码逆向分析

// FNV-1a 32-bit hash function hashString(s) { let h = 2166136261; for (let i = 0; i < s.length; i++) { h ^= s.charCodeAt(i); h = Math.imul(h, 16777619); } return h >>> 0; }

// Генератор PRNG Мульберри32 function mulberry32(seed) { let a = seed >>> 0; return function() { a |= 0; a = (a + 0x6d2b79f5) | 0; let t = Math.imul(a ^ (a >>> 15), 1 | a); t = (t + Math.imul(t ^ (t >>> 7), 61 | t)) ^ t; return ((t ^ (t >>> 14)) >>> 0) / 4294967296; }; }

const SPECIES = [ "duck", "goose", "blob", "cat", "dragon", "octopus", "owl", "penguin", "turtle", "snail", "ghost", "axolotl", "capybara", "cactus", "robot", "rabbit", "mushroom", "chonk" ];const RARITIES = ["common", "uncommon", "rare", "epic", "legendary"]; const RARITYWEIGHTS = { common: 60, uncommon: 25, rare: 10, epic: 4, legendary: 1 }; const SALT = "friend-2026-401";

function pick(rng, arr) { return arr[Math.floor(rng() arr.length)]; }

function rollRarity(rng) { const total = Object.values(RARITYWEIGHTS).reduce((a, b) => a + b, 0); let roll = rng() total; for (const rarity of RARITIES) { roll -= RARITY_WEIGHTS[rarity]; if (roll < 0) return rarity; } return "common"; }

function testUserId(userId) { const key = userId + SALT; const seed = hashString(key); const rng = mulberry32(seed); const rarity = rollRarity(rng); const species = pick(rng, SPECIES); const shiny = rng() < 0.01; return { rarity, species, shiny }; }

function randomUserId() { let id = ""; for (let i = 0; i < 64; i++) { id += Math.floor(Math.random() 16).toString(16); } return id; }

// Поиск блестящего легендарного console.log("Поиск блестящего легендарного Buddy...\n"); const targetSpecies = process.argv[2] || null;

while (true) { const userId = randomUserId(); const result = testUserId(userId);

if (result.rarity === "legendary" && result.shiny) { if (!targetSpecies || result.species === targetSpecies) { console.log("Нашел!"); console.log("Вид:", result.species); console.log("Редкость: Легендарный"); console.log("Блестящий: Да!"); console.log("userID:", userId); break; } } }

Четыре, шаги использования

  • Сохраните скрипт: Сохраните приведенный выше код как buddy-reroll.js

  • Запустите скрипт: node buddy-reroll.js (можно указать вид: node buddy-reroll.js dragon)

  • Скопируйте userID: Скрипт выведет userID блестящего легендарного Buddy- Изменение конфигурации
# Редактируйте ~/.claude.json cat ~/.claude.json | jq '.userID = "ваш новый userID" | del(.companion)' > /tmp/claude-new.json && mv /tmp/claude-new.json ~/.claude.json

  • Перезапустите Claude Code,введите /buddy, чтобы увидеть нового питомца!

Пять, Принципы дизайна защиты от мошенничества

Дизайн Claude Code очень продуман, использует архитектуру разделения скелета (Bones) и души (Soul)

  • Bones(скелет):вид, редкость, внешний вид, свойства——каждый раз пересчитывается из userID, никогда не сохраняется

  • Soul(душа):имя, описание характера——сохраняется в локальной конфигурации
Это означает, что даже если вы напрямую редактируете поле rarity в конфигурационном файле, система перезапишет его результатом roll(userID) при чтении. Комментарий написан очень прямо:редактирование config.companion не может подделать редкость

Но сам userID можно изменить, и именно в этом заключается принцип метода данной статьи.

Шесть, Резюме

Claude Code Buddy — это тщательно продуманная пасхалка, сочетающая в себе:

  • Детерминированный рандом:классическая комбинация FNV-1a + Mulberry32

  • Механизм抽卡:5 уровней редкости + 1% блеска, суть игр Gacha

  • Дизайн защиты от мошенничества:разделение скелета/души, обеспечивающее справедливость

  • Пасхалка на День дурака:значение salt скрывает временную метку 1 апреля
Попробуйте прямо сейчас! Желаю вам получить желаемого блестящего легендарного Buddy!

Ссылки на материалы:

  • Утечка исходного кода Claude Code 2.1.89 (инцидент с картой источников npm)

  • Juejin: 《Глубокое исследование режима Claude Code Buddy: детерминированный случайный алгоритм за кактусом》- DEV.to: Я разобрал исходный код Claude
Published in Technology

You Might Also Like

Obsidian выпустил Defuddle, подняв Obsidian Web Clipper на новый уровеньTechnology

Obsidian выпустил Defuddle, подняв Obsidian Web Clipper на новый уровень

Obsidian выпустил Defuddle, подняв Obsidian Web Clipper на новый уровень Мне всегда нравилась основная идея Obsidian: п...

OpenAI внезапно объявила о "тройном объединении": браузер + программирование + ChatGPT, внутреннее признание ошибок прошлого годаTechnology

OpenAI внезапно объявила о "тройном объединении": браузер + программирование + ChatGPT, внутреннее признание ошибок прошлого года

OpenAI внезапно объявила о "тройном объединении": браузер + программирование + ChatGPT, внутреннее признание ошибок прош...

2026, больше не заставляйте себя "дисциплинироваться"! Сделайте эти 8 простых вещей, и здоровье придет само собойHealth

2026, больше не заставляйте себя "дисциплинироваться"! Сделайте эти 8 простых вещей, и здоровье придет само собой

2026, больше не заставляйте себя "дисциплинироваться"! Сделайте эти 8 простых вещей, и здоровье придет само собой Новый...

Тем мамам, которые стараются похудеть, но не могут, определенно стоит задуматься здесьHealth

Тем мамам, которые стараются похудеть, но не могут, определенно стоит задуматься здесь

Тем мамам, которые стараются похудеть, но не могут, определенно стоит задуматься здесь Март уже почти прошел, как у вас...

📝
Technology

AI Browser 24小时稳定运行指南

AI Browser 24小时稳定运行指南 Этот учебник описывает, как создать стабильную, долгосрочную среду для AI браузера. Подходит для A...

📝
Technology

Наст guide по настройке Agent-Browser: повторное использование состояния входа в браузер через CDP

Наст guide по настройке Agent-Browser: повторное использование состояния входа в браузер через CDP\n\nЭтот гайд поможет ...