AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • Início
  • system&network
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • Início
  • system&network
    • Recentes
    • Highest score
    • tags
  • Ubuntu
    • Recentes
    • Highest score
    • tags
  • Unix
    • Recentes
    • tags
  • DBA
    • Recentes
    • tags
  • Computer
    • Recentes
    • tags
  • Coding
    • Recentes
    • tags
Início / ubuntu / Perguntas / 1168959
Accepted
Jags
Jags
Asked: 2019-08-28 11:05:09 +0800 CST2019-08-28 11:05:09 +0800 CST 2019-08-28 11:05:09 +0800 CST

Como configurar o VSFTPD para acesso somente LAN e restringir o acesso a um único diretório

  • 772

Eu passei por alguns guias de configuração, mas não consegui descobrir como configurar o VSFTPD para acesso somente LAN e restringir o acesso a um único diretório (por exemplo: ~/Downloads).

Se possível, nem quero expor sua presença na Internet. Qualquer ajuda é muito apreciada.

PC: Ubuntu Mate 19.04 64 bits.

vsftpd
  • 1 1 respostas
  • 2489 Views

1 respostas

  • Voted
  1. Best Answer
    user68186
    2019-08-28T15:36:08+08:002019-08-28T15:36:08+08:00

    Acesso somente LAN

    Isso é feito melhor com regras de firewall. Usaremos ufwo firewall descomplicado para isso.

    Primeiro, verificamos o status deufw

    sudo ufw status
    

    Se você vir Status: inactive, use o seguinte comando para ativar ufw:

    sudo ufw enable
    

    Conforme descrito no link abaixo, permitiremos as portas 20 e 21 para o acesso básico do VSFTPD. Não usaremos a regra ufw simples como:

    sudo ufw allow ftp
    

    pois isso permitirá o acesso de qualquer lugar. Para permitir o acesso somente LAN, usaremos a sintaxe avançada:

    sudo ufw allow  from 192.168.0.0/24 to any port 20 proto tcp
    sudo ufw allow  from 192.168.0.0/24 to any port 21 proto tcp
    

    A from 192.168.0.0/24é a parte somente LAN. O seu pode ser diferente. Alguns roteadores domésticos atribuem endereços IP no intervalo 192.168.0.xe outros no intervalo 192.168.1.x, onde x está entre 2-255. A /24máscara de sub-rede diz que qualquer valor de x nesse intervalo é permitido.

    Isso to anysignifica que qualquer endereço IP atribuído a este computador está correto. Como este computador não está atuando como roteador, essa configuração está correta.

    O port 20(ou 21) é a porta que esta regra abre.

    O proto tcpé o único tcpprotocolo (não o udpprotocolo) que pode ser usado.

    Se quisermos adicionar as portas 990 e 40.000 a 50.000 portas ao firewall como no tutorial abaixo, podemos usar um comando para fazer isso:

    sudo ufw allow  from 192.168.0.0/24 to any port 990,40000:50000 proto tcp
    

    Uma nota sobre o IPv6

    Eu não sei o suficiente sobre endereços locais IPv6 e máscaras de sub-rede para escrever uma resposta que inclua regras IPv6 ufw. Sem nenhuma regra de permissão IPv6, qualquer tentativa de usar endereços IPv6 para acessar o ftpsite será negada.

    As respostas a esta pergunta sugerem que pode não haver uma solução fácil para o IPv6: Como permitir sub-redes IPv6 locais no ufw?

    Pelo que vale a pena, a seguinte sintaxe de regra de permissão (com base em uma resposta à pergunta acima) é aceita por ufw:

    sudo ufw allow  from fe80::/64 to any port 21 proto tcp
    

    Isso deve permitir o acesso ftp do intervalo IPv6 de link local que começa com fe80.

    Restringir o usuário a um único diretório

    Isso está muito bem descrito no Tutorial do Oceano Digital . As principais etapas são reproduzidas abaixo:

    Neste exemplo, o nome de usuário é sammy. O conceito básico é que o usuário sammy não deve ter acesso de gravação ao diretório base do diretório acessível ao usuário. Crie a ftppasta, defina sua propriedade e remova as permissões de gravação com os seguintes comandos:

    sudo mkdir /home/sammy/ftp
    sudo chown nobody:nogroup /home/sammy/ftp
    sudo chmod a-w /home/sammy/ftp
    

    Em seguida, criamos o diretório onde os arquivos podem ser carregados e atribuímos a propriedade ao usuário:

    sudo mkdir /home/sammy/ftp/files
    sudo chown sammy:sammy /home/sammy/ftp/files
    

    Em seguida, editamos o arquivo de configuração do VSFTPD no nano:

    sudo nano /etc/vsftpd.conf
    

    e faça as seguintes alterações/adições:

    . . .
    # Allow anonymous FTP? (Disabled by default).
    anonymous_enable=NO
    #
    # Uncomment this to allow local users to log in.
    local_enable=YES
    . . .
    write_enable=YES
    . . .
    chroot_local_user=YES
    . . .
    user_sub_token=$USER
    local_root=/home/$USER/ftp
    . . .
    

    Quando terminarmos de fazer a alteração, salve e saia do arquivo.

    Em seguida, criamos e adicionamos nosso usuário ao arquivo. Usaremos o sinalizador -a para anexar ao arquivo:

    echo "sammy" | sudo tee -a /etc/vsftpd.userlist
    

    Por fim, reiniciamos o daemon para carregar as alterações de configuração:

    sudo systemctl restart vsftpd
    

    Espero que isto ajude

    • 1

relate perguntas

Sidebar

Stats

  • Perguntas 205573
  • respostas 270741
  • best respostas 135370
  • utilizador 68524
  • Highest score
  • respostas
  • Marko Smith

    Existe um comando para listar todos os usuários? Também para adicionar, excluir, modificar usuários, no terminal?

    • 9 respostas
  • Marko Smith

    Como excluir um diretório não vazio no Terminal?

    • 4 respostas
  • Marko Smith

    Como descompactar um arquivo zip do Terminal?

    • 9 respostas
  • Marko Smith

    Como instalo um arquivo .deb por meio da linha de comando?

    • 11 respostas
  • Marko Smith

    Como instalo um arquivo .tar.gz (ou .tar.bz2)?

    • 14 respostas
  • Marko Smith

    Como listar todos os pacotes instalados

    • 24 respostas
  • Martin Hope
    Flimm Como posso usar o docker sem sudo? 2014-06-07 00:17:43 +0800 CST
  • Martin Hope
    led-Zepp Como faço para salvar a saída do terminal em um arquivo? 2014-02-15 11:49:07 +0800 CST
  • Martin Hope
    ubuntu-nerd Como descompactar um arquivo zip do Terminal? 2011-12-11 20:37:54 +0800 CST
  • Martin Hope
    TheXed Como instalo um arquivo .deb por meio da linha de comando? 2011-05-07 09:40:28 +0800 CST
  • Martin Hope
    Ivan Como listar todos os pacotes instalados 2010-12-17 18:08:49 +0800 CST
  • Martin Hope
    David Barry Como determino o tamanho total de um diretório (pasta) na linha de comando? 2010-08-06 10:20:23 +0800 CST
  • Martin Hope
    jfoucher "Os seguintes pacotes foram retidos:" Por que e como resolvo isso? 2010-08-01 13:59:22 +0800 CST
  • Martin Hope
    David Ashford Como os PPAs podem ser removidos? 2010-07-30 01:09:42 +0800 CST

Hot tag

10.10 10.04 gnome networking server command-line package-management software-recommendation sound xorg

Explore

  • Início
  • Perguntas
    • Recentes
    • Highest score
  • tag
  • help

Footer

AskOverflow.Dev

About Us

  • About Us
  • Contact Us

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve