O JJRC H68 é um drone barato que contém uma câmera 720p embutida. O código no repositório permite controlar totalmente o movimento do drone usando um joystick e receber a imagem da câmera (que pode ser usado para processamento de imagens). O código foi escrito em python 3 e testado no Kali Linux 20.02. Para analisar o tráfico, conectei meu celular no app do drone e fiz uma interceptação man-in-the-middle usando o airodump-ng junto com o Wireshark e descobri que o aplicativo usa o protocolo UDP para enviar os comandos de controle e o protocolo TCP para enviar vídeos. https://sites.google.com/site/negocindosica/jjrc%20h68.jpg
sudo apt-get update
- gstreamer - sudo apt-get install gstreamer1.0-tools sudo apt-get install -y gstreamer1.0-plugins-bad
- pygame - sudo apt-get install python3-pygame
- GUI - sudo apt-get install -y qt5-default libvtk6-dev
- tkinter e outros compontentes - sudo apt-get install -y python-dev python-tk pylint python-numpy python3-dev python3-tk pylint3 python3-numpy flake8
- opencv - sudo apt-get install libopencv-dev python3-opencv
- Conecte no wifi do drone
- Execute o arquivo: execute_me.py
Os códigos estão organizados nas seguintes pastas:
- camera - Todos os codigos relacionados a camera
- control - Todos os codigos relacionados ao controle do drone
- general - Codigos gerais
- sniffes - sniffes da comunicao entre o drone e o aplicativo
- Interceptar a rede wlan0 - tcpdump -vv -nn -i wlan0
- Verificar processos que podem conflitar no monitoramento - airmon-ng check
- Desabilitar processos que podem confiltar no monitoramento - airmon-ng check kill
- Monitorar a rede - airmon-ng start wlan0
- Interceptar a rede no modo monitoramento - tcpdump -vv -nn -i wlan0mon
- Setar o monitoriamento para um canal específico - iwconfig wlan0mon channel 2
- Comando para visualisar as redes que estão sendo monitoradas pelo adaptador - airodump-ng wlan0mon
- Monitorar um canal específico - airodump-ng -c 2 wlan0mon
- Sair do modo monitor - airmon-ng stop wlan0mon
- Reiniciar configurações de rede - service network-manager restart