Knockd (bate, bate, bate na porta do céu)
Knockd é um servidor port-knock. Ele escuta todo o tráfego em uma interface Ethernet (ou PPP), procurando por "batidas" sequências de requisições. Um cliente faz requisições para o servidor enviando um pacote TCP (ou UDP) para uma porta no servidor.
[ Hits: 9.419 ]
Por: Bruno Viana em 08/05/2017 | Blog: https://myshell.blog
function printUsage() { echo "" echo "$(basename "$0") -s Server_Knockd -p PORTA1 PORTA2 PORTA2 -P Pora_ssh_diferente" echo "$(basename "$0") -s 192.168.0.222 -p 7000 8000 9000 -P 2222" echo "" echo "-s ou --host: Especifica o servidor alvo" echo "-p ou --port: Especifica as portas para batida (knock)" echo "-P ou --port-ssh: Especifica as porta padrão, se nada for passado sera usado as padrão (22)" echo "" exit } if [ -z "$1" ] || [ -z "$2" ] || [ -z "$3" ] || [ -z "$4" ] || [ -z "$5" ] || [ -z "$6" ];then printUsage fi
while true ;do case "$1" in -s | --host) ip="$2"; shift 2 ;; -p | --port) porta0="$2" porta1="$3" porta2="$4" shift 4 ;; -P | --port-ssh) portaSSH="$2"; shift 2 ;; -h | --help) printUsage ; exit ;; *) break ;; esac done
function verificaPorta() { for port in "$porta0" "$porta1" "$porta2"; do if [ "$port" -lt 1 ] || [ "$port" -gt 65535 ];then echo "A porta deve ser um numero entre 1 e 65535" printUsage fi done }
function testaSSH() { timeout 1 bash -c "echo > /dev/tcp/$ip/$1" }
function openClose() { for i in "$porta0" "$porta1" "$porta2"; do echo > /dev/tcp/"$ip"/"$i" sleep 2 done }
function main() { verificaPorta openClose test -z "$portaSSH" && testaSSH 22 test -n "$portaSSH" && testaSSH "$portaSSH" }
#! /bin/bash # Knock Open Close 0.1 # @Author: Bruno Viana function printUsage() { echo "" echo "$(basename "$0") -s Server_Knockd -p PORTA1 PORTA2 PORTA2 -P Pora_ssh_diferente" echo "$(basename "$0") -s 192.168.0.222 -p 7000 8000 9000 -P 2222" echo "" echo "-s ou --host: Especifica o servidor alvo" echo "-p ou --port: Especifica as portas para batida (knock)" echo "-P ou --port-ssh: Especifica as porta padrao, se nada for passado sera usado as padrao (22)" echo "" exit } if [ -z "$1" ] || [ -z "$2" ] || [ -z "$3" ] || [ -z "$4" ] || [ -z "$5" ] || [ -z "$6" ];then printUsage fi function openClose() { for i in "$porta0" "$porta1" "$porta2"; do echo > /dev/tcp/"$ip"/"$i" sleep 2 done } function testaSSH() { timeout 1 bash -c "echo > /dev/tcp/$ip/$1" } function verificaPorta() { for port in "$porta0" "$porta1" "$porta2"; do if [ "$port" -lt 1 ] || [ "$port" -gt 65535 ];then echo "A porta deve ser um numero entre 1 e 65535" printUsage exit fi done } while true ;do case "$1" in -s | --host) ip="$2"; shift 2 ;; -p | --port) porta0="$2" porta1="$3" porta2="$4" shift 4 ;; -P | --port-ssh) portaSSH="$2"; shift 2 ;; -h | --help) printUsage ; exit ;; *) break ;; esac done function main() { verificaPorta openClose test -z "$portaSSH" && testaSSH 22 test -n "$portaSSH" && testaSSH "$portaSSH" } main # End of scrpit
Elevação de privilégios locais
Prevenção e rastreamento de um ataque
Instalando o Nagios via APT ou YUM
Desvendando código malicioso no fórum Viva o Linux
Atualizar o macOS no Mac - Opencore Legacy Patcher
Crie alias para as tarefas que possuam longas linhas de comando - bash e zsh
Criando um gateway de internet com o Debian
Configuração básica do Conky para mostrar informações sobre a sua máquina no Desktop
Aprenda a criar músicas com Inteligência Artificial usando Suno AI
Instalando Zoom Client no Ubuntu 24.04 LTS
Instalando Zoom Client no Fedora 40
Instalando Navegador Firefox no Debian 12
Bloqueando propagandas no Youtube e outros sites com o uBlocker Origin
Servidor Samba 4.15.13 AD-DC (3)
Não consigo atualizar minha GPU (0)
Sistema da Coréia do Norte - Red Star OS (56)