Wireshark MCP Server
Provides network packet analysis capabilities via Wireshark/tshark, including live packet capture, PCAP analysis, protocol statistics, stream reconstruction, file extraction, credential extraction, and HTTP object export.
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., "@Wireshark MCP Serveranalyze the pcap file for DNS queries"
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.
Wireshark MCP Server
A Model Context Protocol (MCP) server that provides network packet analysis capabilities via Wireshark/tshark on a remote machine (e.g., Kali Linux).
This server enables AI assistants to perform sophisticated network traffic analysis, packet capture, protocol inspection, and security-focused operations through a standardized MCP interface.
Features
Live Packet Capture - Capture network traffic on remote interfaces with BPF filters
PCAP Analysis - Read and analyze existing pcap files
Protocol Statistics - Generate protocol hierarchy, conversations, endpoints, and I/O statistics
Stream Reconstruction - Follow TCP, UDP, HTTP, and TLS streams
File Extraction - Extract files from HTTP, SMB, DICOM, IMF, and TFTP traffic
Deep Packet Inspection - Decode packets with full protocol details
Credential Extraction - Search for credentials in HTTP Basic Auth, FTP, Telnet, and form submissions
HTTP Object Export - List and export HTTP objects from captures
Prerequisites
Node.js 18+
SSH access to a remote machine with tshark installed (e.g., Kali Linux)
SSH key-based authentication configured (password-less)
sudoaccess on the remote machine for packet capture
Installation
git clone https://github.com/schwarztim/sec-wireshark-mcp.git
cd sec-wireshark-mcp
npm install
npm run buildConfiguration
Set the following environment variables:
Variable | Description | Default |
| SSH hostname or IP of the remote machine |
|
| SSH username (optional if using SSH config) | (empty) |
| Directory on remote host for pcap files |
|
Example Configuration
export WIRESHARK_SSH_HOST="192.168.1.100"
export WIRESHARK_SSH_USER="kali"Or use an SSH config entry:
# ~/.ssh/config
Host kali
HostName 192.168.1.100
User kali
IdentityFile ~/.ssh/id_rsaUsage with Claude Desktop
Add to your Claude Desktop configuration (~/.claude/user-mcps.json or Claude Desktop settings):
{
"mcpServers": {
"wireshark": {
"command": "node",
"args": ["/path/to/sec-wireshark-mcp/dist/index.js"],
"env": {
"WIRESHARK_SSH_HOST": "kali",
"WIRESHARK_SSH_USER": "kali"
}
}
}
}Available Tools
tshark_list_interfaces
List available network interfaces on the remote machine for packet capture.
tshark_capture
Start packet capture on a specified interface.
Parameters:
interface(required): Network interface (e.g.,eth0,wlan0)count: Number of packets to capture (default: 10, max: 1000)filter: BPF capture filter (e.g.,port 80,host 192.168.1.1)timeout: Capture timeout in seconds (default: 10, max: 60)outputFile: Save capture to pcap file on remote host
tshark_read_pcap
Read and analyze a pcap file.
Parameters:
file(required): Path to the pcap file on remote hostfilter: Wireshark display filtercount: Maximum packets to return (default: 100, max: 1000)fields: Specific fields to extract (e.g.,['ip.src', 'ip.dst', 'tcp.port'])
tshark_filter
Apply a display filter to a pcap file.
Parameters:
file(required): Path to the pcap filefilter(required): Display filter (e.g.,http.request,dns,tcp.flags.syn == 1)outputFormat:json,text, orfields(default:json)fields: Fields to extract when usingfieldsformat
tshark_stats
Generate protocol statistics from a pcap file.
Parameters:
file(required): Path to the pcap filetype(required):hierarchy,conversations,endpoints,io,http, ordnsprotocol: Protocol for conversations/endpoints (e.g.,tcp,udp,ip)
tshark_follow_stream
Reconstruct a TCP, UDP, HTTP, or TLS stream.
Parameters:
file(required): Path to the pcap fileprotocol(required):tcp,udp,http, ortlsstreamIndex: Stream index number (default: 0)format:ascii,hex, orraw(default:ascii)
tshark_extract_files
Extract files from protocol traffic.
Parameters:
file(required): Path to the pcap fileprotocol:http,dicom,imf,smb, ortftp(default:http)outputDir: Directory for extracted files (default:/tmp/mcp-extracted)
tshark_decode
Deep packet inspection with full protocol details.
Parameters:
file(required): Path to the pcap filepacketNumber: Specific packet number to decodefilter: Display filter to select packetsprotocols: Specific protocols to show (e.g.,['http', 'tcp', 'ip'])verbose: Show all protocol details (default: false)
tshark_extract_credentials
Search for potential credentials in network traffic.
Parameters:
file(required): Path to the pcap file
Searches for HTTP Basic Auth, FTP credentials, HTTP POST form data, and Telnet data.
tshark_export_objects
List and export HTTP objects from a capture.
Parameters:
file(required): Path to the pcap filelistOnly: Only list objects without extracting (default: true)outputDir: Directory for extracted objects
Security Considerations
This server executes commands on a remote machine via SSH
Input sanitization is implemented to prevent command injection
Use SSH key authentication with appropriate permissions
Consider network segmentation for the capture machine
The remote machine requires
sudoaccess for live captureCredential extraction features should be used only for authorized security testing
Development
# Run in development mode
npm run dev
# Build for production
npm run build
# Start production server
npm startLicense
MIT License - see LICENSE for details.
Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
Related Projects
Model Context Protocol - The protocol specification
Wireshark - Network protocol analyzer
tshark - Terminal-based Wireshark
This server cannot be installed
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/schwarztim/sec-wireshark-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server