Skip to content

⚡ A high-performance network diagnostics toolkit with Multi-Protocol Support, including TCP and UDP.

License

Notifications You must be signed in to change notification settings

luhuadong/zapnet

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

12 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

ZapNet ⚡

License: MIT Python Version PyPI Version

中文 | English

ZapNet is a high-performance network diagnostics toolkit with Multi-Protocol Support, including TCP and UDP.

Key Features

  • 🚀 Dual Protocol Engine: TCP full-duplex / UDP broadcast
  • 📊 Traffic Analytics: Real-time connection monitoring
  • 🔧 Smart Config: YAML-driven test scenarios
  • 💾 Data Archiving: Raw packet capture (ASCII/Hex)
  • 🌍 Cross-Platform: Windows/macOS/Linux support

Installation

# For production use
pip install zapnet

# Development setup
git clone https://github.com/luhuadong/zapnet.git
cd zapnet && pip install -e .[dev]

Quick Start

TCP Server/Client

# Start TCP server
zapnet tcp server --port 5555

# Start TCP client
zapnet tcp client --host 127.0.0.1 --port 5555 --data "Hello, World"
# Send hexadecimal content
zapnet tcp client --host 127.0.0.1 --port 5555 --hex "A1B2C3D4"
# Another form to fill in target IP and port
zapnet tcp client --target 127.0.0.1:5555 --hex "A1B2C3D4"

UDP Server/Client

# Start UDP server
zapnet udp server --port 6666

# Start UDP client
zapnet udp client --host 127.0.0.1 --port 6666 --data "Hello, World"
# Send hexadecimal content
zapnet udp client --host 127.0.0.1 --port 6666 --hex "A1B2C3D4"
# Another form to fill in target IP and port
zapnet udp client --target 127.0.0.1:6666 --hex "A1B2C3D4"

Device Discovery (UDP Broadcast)

# Send probe broadcast
zapnet udp client --target 192.168.1.255:9999 --broadcast --hex "A1B2C3D4"

# Monitor responses
zapnet udp server --port 9999 --filter "hex_contains(payload, 'C3D4')" --output devices.log

Network Sniffing (UDP)

# Capture DNS queries
zapnet udp server --port 53 --hex --stats 5

# Send custom DNS query
zapnet udp client --target 8.8.8.8:53 --hex "b362010000010000000000000377777706676f6f676c6503636f6d0000010001"

TCP Stress Testing

# Start TCP server
zapnet tcp server --port 9000 --max-conn 50 --timeout 300

# Simulate high concurrency
zapnet tcp client --host 127.0.0.1 --port 9000 --threads 10 --duration 60 --message "LOAD_TEST"

File Transfer

# Send file (TCP)
zapnet tcp client --host 192.168.1.100 --port 8888 --file data.zip

# Receive files
zapnet tcp server --port 8888 --output received_files/

Advanced Configuration

You can set default parameters through ZapNet's configuration file config.yaml, for example:

network:
  tcp:
    buffer_size: 4096
    keepalive: true
  udp:
    broadcast_ttl: 64

logging:
  level: debug
  rotation: 100MB

security:
  allowed_ips: ["192.168.1.0/24"]

Launch with:

zapnet --config config.yaml

License

Distributed under the MIT License. See LICENSE for more information.

About

⚡ A high-performance network diagnostics toolkit with Multi-Protocol Support, including TCP and UDP.

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages