Cover image
Try Now
2025-04-08

Another™ MCP Server for Binary Ninja with superpower 🥵

3 years

Works with Finder

3

Github Watches

4

Github Forks

19

Github Stars

Another™ MCP Server for Binary Ninja

The MCP (Model Context Protocol) Server for Binary Ninja

PyPI Apache licensed Python Version GitHub Discussions

English | 中文

Demo

The tests/binary/beleaf.elf is taken from CSAW'19: Beleaf - Nightmare. You can also find the complete writeup from the link above!

demo

... but why Another?

See: Key Differences from the Existing Plugin

Installation

Server Setup

There are two ways to run the MCP server:

  1. Binary Ninja UI Plugin:

    • Install the plugin via Binary Ninja's plugin manager
    • The MCP server will start automatically when first file is loaded.
      • Auto start is configurable via Settings - MCP Server - Auto Start
      • Listen port is configurable via Settings - MCP Server - Server port number
    • All opened files are exposed to separate resources, see Available Resources section below
  2. Binary Ninja Headless Mode:

    uvx binaryninja-mcp install-api  # only run once
    uvx binaryninja-mcp server <filename> [filename]...
    
    • filename could be any binary files or BNDB, like in UI mode, all opened files are available to the MCP client.
    • Server runs on default port 7000
    • Use --port flag to specify a different port

MCP Client Setup

  1. Claude Desktop (stdio relay client): Configure the client to connect via stdio transport using built-in relay.

    {
      "mcpServers": {
        "binaryninja": {
          "command": "uvx",
          "args": ["binaryninja-mcp", "client"]
        }
      }
    }
    
  2. Cherry Studio:

    • SSE endpoint (recommanded): URL: http://localhost:7000/sse
    • stdio client:
      • Command: uvx
      • Arguments:
        binaryninja-mcp
        client
        

Add --port 12345 to both server and client command line if you prefer to run MCP server on port other than default.

Available Tools for MCP Clients

The MCP server provides the following tools:

  • rename_symbol: Rename a function or a data variable
  • pseudo_c: Get pseudo C code of a specified function
  • pseudo_rust: Get pseudo Rust code of a specified function
  • high_level_il: Get high level IL of a specified function
  • medium_level_il: Get medium level IL of a specified function
  • disassembly: Get disassembly of a function or specified range
  • update_analysis_and_wait: Update analysis for the binary and wait for completion
  • get_triage_summary: Get basic information from BinaryNinja Triage view
  • get_imports: Get dictionary of imported symbols
  • get_exports: Get dictionary of exported symbols
  • get_segments: Get list of memory segments
  • get_sections: Get list of binary sections
  • get_strings: Get list of strings found in the binary
  • get_functions: Get list of functions
  • get_data_variables: Get list of data variables

Available Resources for MCP Clients

MCP Resources can be accessed via URIs in the format: binaryninja://{filename}/{resource_type}

The server provides these resource types for each binary:

  • triage_summary: Basic information from BinaryNinja Triage view
  • imports: Dictionary of imported symbols/functions
  • exports: Dictionary of exported symbols/functions
  • segments: List of memory segments
  • sections: List of binary sections
  • strings: List of strings found in the binary
  • functions: List of functions
  • data_variables: List of data variables

Development

uv is the recommanded package management tool for this project.

Clone directory to Binary Ninja Plugin Directory

git clone https://github.com/MCPPhalanx/binaryninja-mcp.git "${env:APPDATA}\Binary Ninja\plugins\MCPPhalanx_binaryninja_mcp"

Setup Python Environment

Binary Ninja API must be installed into virtualenv manually.

uv venv
uv sync --dev
# install binaryninja API
binaryninja-mcp install-api
# check API is correctly installed
uv run python -c 'import binaryninja as bn; print(f"ui_enabled={bn.core_ui_enabled()}")'

Setup MCP Client for Development

For MCP clients with stdio transport like Claude Desktop, change working directory to development folder.

{
  "mcpServers": {
    "binaryninja": {
      "command": "uv",
      "args": [
        "--directory",
        "C:/path/to/binaryninja-mcp",
        "run",
        "binaryninja-mcp",
        "client"
      ]
    }
  }
}

SSE-enabled MCP clients can connect using: http://localhost:7000/sse

Build

uv build

Test

pytest
# To update test snapshots:
pytest --snapshot-update

Version Bump

The PyPI package version is automatically derived from Binary Ninja's plugin.json (using package.json format), maintaining version consistency between the BN plugin and PyPI package.

# bump alpha version
uvx hatch version a

# bump release version
uvx hatch version minor,rc
uvx hatch version release

See: Versioning - Hatch

Release

uv publish

License

Apache 2.0

相关推荐

  • NiKole Maxwell
  • I craft unique cereal names, stories, and ridiculously cute Cereal Baby images.

  • Bora Yalcin
  • Evaluator for marketplace product descriptions, checks for relevancy and keyword stuffing.

  • Joshua Armstrong
  • Confidential guide on numerology and astrology, based of GG33 Public information

  • https://suefel.com
  • Latest advice and best practices for custom GPT development.

  • Emmet Halm
  • Converts Figma frames into front-end code for various mobile frameworks.

  • Elijah Ng Shi Yi
  • Advanced software engineer GPT that excels through nailing the basics.

  • https://maiplestudio.com
  • Find Exhibitors, Speakers and more

  • Lists Tailwind CSS classes in monospaced font

  • lumpenspace
  • Take an adjectivised noun, and create images making it progressively more adjective!

  • Yasir Eryilmaz
  • AI scriptwriting assistant for short, engaging video content.

  • apappascs
  • Discover the most comprehensive and up-to-date collection of MCP servers in the market. This repository serves as a centralized hub, offering an extensive catalog of open-source and proprietary MCP servers, complete with features, documentation links, and contributors.

  • ShrimpingIt
  • Micropython I2C-based manipulation of the MCP series GPIO expander, derived from Adafruit_MCP230xx

  • jae-jae
  • MCP server for fetch web page content using Playwright headless browser.

  • HiveNexus
  • An AI chat bot for small and medium-sized teams, supporting models such as Deepseek, Open AI, Claude, and Gemini. 专为中小团队设计的 AI 聊天应用,支持 Deepseek、Open AI、Claude、Gemini 等模型。

  • ravitemer
  • A powerful Neovim plugin for managing MCP (Model Context Protocol) servers

  • patruff
  • Bridge between Ollama and MCP servers, enabling local LLMs to use Model Context Protocol tools

    Reviews

    2 (1)
    Avatar
    user_XzwOa7qW
    2025-04-16

    I've been using binaryninja-mcp by MCPPhalanx, and it has significantly enhanced my binary analysis workflow. The seamless integration and comprehensive features make it a standout tool for any reverse engineer. Highly recommend checking it out at https://github.com/MCPPhalanx/binaryninja-mcp!