httptoolkit-mcp
Provides ADB-based automation for Android emulators (Nox, MEmu, BlueStacks, LDPlayer) to install system CA certificates and configure proxy settings without UI, including support for transparent iptables interception.
Allows interception and deep protobuf reverse-engineering of Spotify's binary protobuf API, including decoding compressed subfields and diffing messages to identify changing fields like cursors and tokens.
Identifies that WhatsApp traffic uses end-to-end encryption (Noise Protocol and Signal E2E) and thus cannot be decrypted via passive MITM; provides classification to mark such traffic as encrypted.
Supports decoding of base64url-encoded protobuf tokens (e.g., continuation, params, clickTrackingParams) within YouTube's InnerTube JSON API, with automatic unwrapping and comparison via protobuf_diff.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@httptoolkit-mcpStart proxy and setup transparent interception for Nox emulator"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
httptoolkit-mcp
MCP-сервер для перехвата и мокинга HTTP(S)-трафика. Построен на Mockttp - том же движке, что и HTTP Toolkit, - поэтому самому десктоп-приложению он не нужен: MCP сам поднимает перехватывающий proxy. Заточен под Android-эмуляторы (Nox, MEmu, BlueStacks, LDPlayer) и настройку только через adb.
Что умеет
Перехват HTTP(S) через свой Mockttp-proxy (стабильный CA между перезапусками).
Разбор обмена: request/response заголовки, request/response cookies, тело в форматах text / json / hex / protobuf / base64.
Глубокий protobuf-реверс (для «грязных» API типа Spotify/YouTube): schema-less декод, который держит все трактовки поля сразу (вложенное сообщение / строка / байты), авто-распаковка вложенных gzip/zlib/zstd-блобов с рекурсивным декодом, снятие gRPC-framing, JSON-дерево для автоматизаций и diff двух сообщений по путям полей (чтобы видеть, что меняется: курсоры, токены, id).
Spotify - бинарный protobuf в теле (часто со сжатыми под-полями).
YouTube/InnerTube - JSON по HTTPS, где токены (
continuation,params,clickTrackingParams) - это base64url-protobuf внутри строк. Декодер принимает base64url на входе и сам разворачивает такие токены, в т.ч. многослойные;protobuf_diffсравнивает их внутренности по путям.
Правила: мок-ответы, инъекция ошибок (reset/timeout/close), задержки, редиректы, модификация заголовков/тела запроса.
Анализ/экспорт: фильтр, полнотекстовый поиск, экспорт HAR и импорт HAR (например, из самого HTTP Toolkit) для анализа в Claude.
adb-автоматизация: установка CA в системное хранилище и проброс прокси без UI, с автодетектом root-режима и пресетами портов эмуляторов. Поддержка Android 7/9 (прямая запись), 10-13 (tmpfs-overlay), 14 (APEX
conscrypt+ namespace-наложение).Прозрачный перехват через
iptablesDNAT - весь TCP :80/:443 уходит на прокси без компаньон-приложения и без VPN-диалога (adb-аналог VPN-режима HTTP Toolkit). Mockttp определяет цель по Host/SNI.WebSocket: перехват ws/wss, сообщения обоих направлений (sent/received) с телом в любом формате (включая protobuf) + код/причина закрытия.
Related MCP server: Android Proxy MCP
Установка
npm install
npm run buildТребуется openssl в PATH (для вычисления subject_hash_old имени системного серта).
Подключение к Claude Desktop
В claude_desktop_config.json:
{
"mcpServers": {
"httptoolkit": {
"command": "node",
"args": ["/absolute/path/to/httptoolkit_mcp/dist/index.js"],
"env": {
"HTMCP_ADB_PATH": "/path/to/adb"
}
}
}
}Переменные окружения:
HTMCP_ADB_PATH- путь к adb. Можно не задавать: сервер сам ищет adb от Nox/MEmu/BlueStacks/LDPlayer/Genymotion/Android SDK, затемadbиз PATH.HTMCP_CERT_DIR- где хранить CA (по умолчанию./certs).
Типовой сценарий (эмулятор)
proxy_start- поднять proxy (по умолчанию порт 8000). В ответе будут локальные IP машины.adb_connectс пресетом (nox/memu/bluestacks/ldplayer) илиhost:port. Список -list_emulator_presets.adb_setup(безhostIp) - рекомендуется: ставит CA и прокидывает прокси через adb reverse tunnel (127.0.0.1). Работает на эмуляторах за NAT (например MEmu, где gateway - виртуальный роутер эмулятора, а не хост), без доступного LAN-IP и в обход firewall. Если хост виден в LAN - передайhostIp.Альтернатива:
adb_setup_transparent(hostIp) - прозрачный iptables-перехват (ловит всё, без диалогов; нужен доступный с устройства хост).http_proxyслетает при перезагрузке Android - перезапустиadb_setup.Перезагрузи приложение, если серт не подхватился.
Гоняй трафик в эмуляторе ->
list_traffic,search_traffic,get_exchange(сbodyFormat: protobufдля protobuf-API),export_har.Мокинг:
add_mock_rule,add_error_rule,add_delay_rule,add_redirect_rule,add_modify_request_rule.
Про «без root» - честно
Запись системного сертификата в принципе требует root-привилегий на уровне
ОС: писать в /system/etc/security/cacerts/ (или накладывать туда tmpfs)
нельзя без root-доступа. Фокус в том, что на эмуляторах этот доступ даётся
через adb без установки Magisk:
Nox / MEmu -
adbdуже работает как root,adb rootпроходит из коробки.BlueStacks / LDPlayer - включи тумблер Root в настройках эмулятора, дальше работает
su(Magisk не нужен).AOSP/Genymotion -
google_apis-образы пускаютadb root;Google Play-образы - нет.
То есть «чисто на adb, без Magisk» - да; но adb должен иметь root-доступ,
который эмулятор предоставляет сам. Установщик автоматически выбирает режим
(adb root -> прямая запись на Android 7/9; su + tmpfs-overlay на 10/11/12).
Системный серт лучше user-серта не только тем, что ему доверяют все приложения, но и тем, что анти-MITM проверки user-store его не видят.
Классификатор блобов
classify_blob по неизвестным байтам (тело обмена или вставленный hex/base64)
говорит, что это: энтропия + magic-байты + пробы JSON/protobuf/base64/gRPC.
Главное - он сразу отсекает то, что декодировать бессмысленно: высокоэнтропийный
шифротекст. Подсказывает следующий шаг (decode_protobuf, распаковка, base64).
Шифрованные транспорты (WhatsApp и т.п.) - не декодируются
Если приложение шифрует трафик на своём уровне (WhatsApp: Noise Protocol +
Signal E2E), пассивный MITM-перехват - даже с нашим системным CA - даёт только
шифротекст. Это не «непонятный формат», а данные на ключах, которых у прокси
нет. classify_blob помечает такой трафик прямо.
Декодировать его перехватом нельзя в принципе. Рабочий путь - стать клиентом (реализация протокола: Baileys/whatsmeow - pairing по QR, свои Noise/Signal ключи), что является отдельным классом задач и в этот MITM-инструмент не входит. Frida/root-хук на расшифрованные функции отпадает: integrity-аттестация на регистрации палит и root, и эмулятор, и сам системный CA.
Ограничение: pinning
Если приложение жёстко пинит сертификат (хардкод в коде), системный CA не поможет - нужен Frida/патч APK, что вне adb-only сценария. Но приложения, полагающиеся на системный trust-store (Яндекс.Музыка, YouTube и большинство обычных), перехватываются полностью.
Реверс protobuf-API (например, Spotify)
Сценарий «дать Claude глаза», чтобы он собрал понимание API для автоматизации:
Перехвати мобильный трафик (
adb_setup_transparent) - у мобильного API чистый protobuf/JSON и меньше анти-фрод триггеров, чем у web/desktop.list_traffic/search_traffic-> найди нужный запрос.decode_protobuf{ id, side: "response", output: "json" }- получишь дерево, где у каждого поля видны все трактовки (message/string/bytes) и распакованные gzip/zstd-вложения. Для gRPC добавьgrpc: true.Сделай два похожих запроса (например, разные страницы/треки) и
protobuf_diff{ a, b, side: "response" }- увидишь, какие поля меняются (курсоры, токены, id), а какие постоянны. Это и есть карта для автоматизации.Проверяй гипотезы запросов через
add_modify_request_rule/add_mock_rule.
Тесты
npm run build && node test/smoke.mjs # ядро: перехват, правила, HAR, cookies
node test/ws-smoke.mjs # WebSocket-перехват сквозь прокси
node test/protobuf-smoke.mjs # protobuf: gzip-вложения, gRPC, diff, base64url-токены
node test/classify-smoke.mjs # классификатор: JSON/protobuf/gzip/шифротекст
node test/mcp-handshake.mjs # MCP stdio handshake + tools/listИнструменты (35)
Прокси: proxy_start, proxy_stop, proxy_status, get_ca_certificate.
Трафик: list_traffic, search_traffic, get_exchange, get_ws_messages,
get_body, clear_traffic, export_har, import_har.
Protobuf: decode_protobuf, protobuf_diff, classify_blob.
Правила: add_mock_rule, add_error_rule, add_delay_rule,
add_redirect_rule, add_modify_request_rule, list_rules, remove_rule,
clear_rules.
ADB/устройство: adb_devices, adb_connect, list_emulator_presets,
adb_reverse, adb_install_cert, adb_set_proxy, adb_clear_proxy, adb_setup,
adb_enable_transparent, adb_disable_transparent, adb_transparent_status,
adb_setup_transparent.
This server cannot be installed
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/FL1NEE/httptoolkit_mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server