Eu preciso da sintaxe correta do tftp para obter e colocar o arquivo. Meu objetivo final é usar o tftp do busybox (esta deve ser a segunda pergunta), mas falhou mesmo tentando testar com o cliente tftp local do Ubuntu.
Como você pode ver abaixo, ftp
nenhum problema, apenas tftp
tem problema. E este é o ip de loopback, portanto, não deve estar relacionado ao iptables (novamente, ftp
sem problemas). Para evitar um possível problema de caminho longo, testo apenas com o diretório inicial.
xb@dnxb:/tmp$ grep anon_root /etc/vsftpd.conf
anon_root=/home/xiaobai/
xb@dnxb:/tmp$ cat /home/xiaobai/haha
7
xb@dnxb:/tmp$ ftp 127.0.0.1
Connected to 127.0.0.1.
220 (vsFTPd 3.0.3)
Name (127.0.0.1:xiaobai): anonymous
331 Please specify the password.
Password:
230 Login successful.
Remote system type is UNIX.
Using binary mode to transfer files.
ftp> get haha
local: haha remote: haha
200 PORT command successful. Consider using PASV.
150 Opening BINARY mode data connection for haha (2 bytes).
226 Transfer complete.
2 bytes received in 0.00 secs (6.5541 kB/s)
ftp> 221 Goodbye.
xb@dnxb:/tmp$ tftp 127.0.0.1
tftp> get haha
Error code 1: File not found
tftp> get /home/xiaobai/haha
Error code 1: File not found
tftp> get /home/xiaobai/haha output
Error code 1: File not found
tftp> put /home/xiaobai/haha
Error code 1: File not found
tftp> put haha
Error code 1: File not found
tftp> xb@dnxb:/tmp$ dpkg-query -W -f='${Description}\n\n${Homepage}\nMaintainer: ${Maintainer}\n\n' tftp
Trivial file transfer protocol client
Tftp is the user interface to the Internet TFTP (Trivial File Transfer
Protocol), which allows users to transfer files to and from a remote machine.
The remote host may be specified on the command line, in which case tftp uses
host as the default host for future transfers.
http://www.hcs.harvard.edu/~dholland/computers/netkit.html
Maintainer: Ubuntu Developers <[email protected]>
xb@dnxb:/tmp$
Então eu sigo esta resposta :
xb@dnxb:/tmp$ tftp -v 127.0.0.1 -c get haha
usage: tftp host-name [port]
tftp> xb@dnxb:/tmp$
xb@dnxb:/tmp$ tftp -v 127.0.0.1 -c get /home/xiaobai/haha
usage: tftp host-name [port]
tftp> xb@dnxb:/tmp$
xb@dnxb:/tmp$ tftp -v 127.0.0.1 -c put haha
usage: tftp host-name [port]
tftp> xb@dnxb:/tmp$ tftp -v 127.0.0.1 -c put /home/xiaobai/haha
usage: tftp host-name [port]
tftp> ^F
?Invalid command
tftp> xb@dnxb:/tmp$
xb@dnxb:/tmp$
E também esta resposta (comente ou não parece não ter efeito, eu fiz service vsftpd restart
depois de editado):
xb@dnxb:/tmp$ grep server_args /etc/xinetd.conf
# server_args = -c -s /tftpboot
xb@dnxb:/tmp$
Poderia ser melhor se alguém pudesse responder sobre o tftp do busybox que tem uma opção diferente:
# busybox tftp
BusyBox v1.22.1 bionic (2017-11-04 12:54 +0800) multi-call binary.
Usage: tftp [OPTIONS] HOST [PORT]
Transfer a file from/to tftp server
-l FILE Local FILE
-r FILE Remote FILE
-g Get file
-p Put file
tftp geralmente é restrito ao diretório /tftpboot, eu não esperaria que funcionasse para obter algo de um diretório inicial do usuário.
Verifique também as permissões do arquivo. IIRC (já faz um tempo), já que o tftp é não autenticado, os arquivos precisam ser legíveis pelo mundo.