drozer-mcp
Provides tools for enumerating and attacking Android IPC components (activities, services, broadcast receivers, content providers) to surface vulnerabilities, leveraging the Drozer framework.
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., "@drozer-mcpScan all installed apps for SQL injection vulnerabilities"
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.
drozer-mcp
MCP server wrapping Drozer for LLM-driven Android IPC security testing.
Lets any Model Context Protocol client — Claude Code, Claude Desktop, Cursor, LM Studio, custom agents — drive Drozer autonomously. The LLM enumerates exported activities, services, broadcast receivers, and content providers across installed apps, then exercises them with intents, broadcasts, and provider queries to surface IPC vulnerabilities.
Designed for the gap in the mobile-security-AI landscape: while there are solid MCP wrappers for Frida, JADX, and MobSF, the canonical Android IPC tool — Drozer — has had no agentic interface until now.
Status
Alpha. Working core: connection lifecycle, package/component enumeration, content provider querying, intent launching, and the most commonly-used scanner modules. Tested against the Drozer 3.1.x console.
Related MCP server: re-mcp
Install
pip install drozer-mcpOr from source:
git clone https://github.com/YOUR-USERNAME/drozer-mcp
cd drozer-mcp
pip install -e .You also need:
A working Drozer install (
pip install drozerplus a Java runtime). The MCP server shells out to thedrozerbinary.The Drozer agent APK running on a rooted physical device or emulator. Download from the Drozer releases page.
ADB port forwarding:
adb forward tcp:31415 tcp:31415
Configure your MCP client
Claude Desktop / Claude Code
Add to ~/.config/claude/claude_desktop_config.json (Linux) or the equivalent
on macOS / Windows:
{
"mcpServers": {
"drozer": {
"command": "drozer-mcp"
}
}
}Restart the client. The Drozer tools will appear with the drozer__ prefix.
Environment variables
Variable | Purpose | Default |
| Path to the |
|
| Override the agent host:port | drozer's own default |
| Log level: |
|
Tools
Connection
Tool | Purpose |
| Open a console session against the agent |
| Close the session |
The first non-connection tool call connects implicitly. If the underlying console dies (agent crash, ADB hiccup), the next call transparently reconnects.
Enumeration
Tool | Drozer command | Returns |
|
| List of package names |
|
| Per-kind counts + |
|
| Components with required permissions |
|
| Same shape as activities |
|
| Same shape |
|
| Same shape |
|
| Deduped list of |
Attacks
Tool | Drozer command | Purpose |
|
| Read a provider with full WHERE/projection/sort args |
|
| Read file-backed providers (FileProvider path-traversal) |
|
| Launch with component / action / data / extras |
|
| Start or bind a service with intent params |
|
| Send a broadcast intent |
Scanners
Tool | Drozer module | Finds |
|
| SQLi in content providers |
|
| Directory traversal in file providers |
|
| Deep-link / URL scheme entry points |
Shell + escape hatch
Tool | Purpose |
| Run a shell command on the device via |
| Run any Drozer command verbatim — for modules not yet wrapped |
Example session (Claude Code)
You: Find SQL injection in any installed app.
Claude: [calls list_packages with filter="com.example"]
[calls package_attack_surface for each result]
[calls scan_provider_injection for those with providers exported]
[calls query_provider with payloads on each finding]
Found 1 injection in com.example.app's UserProvider:
URI: content://com.example.app.provider/users
Injectable parameter: selection
PoC: query with selection="1=1 UNION SELECT password FROM ..."
returned 47 rows including hashed credentials.Why a long-lived console?
Drozer's console connect starts a JVM-backed REPL that talks to the agent over
a TCP port. Cold-start is ~1-2 seconds; once warm, command roundtrips are
sub-second. Re-spawning per tool call would make an LLM-driven workflow painfully
slow, so this MCP server runs a single pexpect-managed session and dispatches
each tool call to it as a REPL command.
That comes with one caveat: the session is not thread-safe. The MCP runtime
serializes tool calls per server process, which makes this safe in practice. If
you want parallel scans of multiple devices, run multiple MCP server instances
with different DROZER_SERVER settings.
Roadmap
More scanners:
scanner.misc.checkparcel,scanner.misc.native, the fullscanner.misc.*family.Structured JSON output mode for
query_provider(currently raw text).Drozer Module API integration so custom modules show up automatically.
iOS / Objective-C equivalents (probably a separate
frida-ios-mcprather than shoehorning here).
License
Apache-2.0.
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/prathx0/drozer-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server