Netgate Discussion Forum
    • Categories
    • Recent
    • Tags
    • Popular
    • Users
    • Search
    • Register
    • Login

    [RESOLVIDO_ABERTO-COMENTAR]Não acesso servidor ftp externamente!

    Scheduled Pinned Locked Moved Portuguese
    18 Posts 5 Posters 5.6k Views
    Loading More Posts
    • Oldest to Newest
    • Newest to Oldest
    • Most Votes
    Reply
    • Reply as topic
    Log in to reply
    This topic has been deleted. Only users with topic management privileges can see it.
    • C
      claudevan
      last edited by

      Vasculhado na NET vir em um topico de um usuário a forma que ele fez para liberar o "FTP" na empresa dele. Eu estou usando o CentOS 6.5 e o servidor ftp (vsftpd) e comigo funcionou a liberação de portas no NAT do Firewall pfsense.

      Link onde eu vir a dica!
      https://forum.pfsense.org/index.php?topic=44733.0

      Fiz uma "aliases" chamado "Portas_ftp" e nele coloque as seguintes portas: 20, 21, 22, 1024:6500, 443 e liberei uma regra de firewall NAT como segui na imagem em anexo.

      Tentei de varias outras formas e não conseguir conectar!  da forma descrita acima funcionou!

      ftp2.png
      ftp2.png_thumb
      ftp3.png
      ftp3.png_thumb

      1 Reply Last reply Reply Quote 0
      • marcellocM
        marcelloc
        last edited by

        @claudevan:

        Fiz uma "aliases" chamado "Portas_ftp" e nele coloque as seguintes portas: 20, 21, 22, 1024:6500, 443 e liberei uma regra de firewall NAT como segui na imagem em anexo.

        Claudevan:

        • porta 443 é https, não é ftp

        • porta 22 é ssh, você está expondo o ssh do seu servidor ftp para qualquer um tentar acertar a senha.

        • a porta 20, como informei no post anterior, é no sentido inverso, ou seja o server solicita a conexão ao cliente com porta oritem 20, essa regra que você criou não vai alcançar essa comunicação

        • 1024:65000, você liberou acesso a qualquer porta alta, o que pode ser um risco para sua segurança.

        Treinamentos de Elite: http://sys-squad.com

        Help a community developer! ;D

        1 Reply Last reply Reply Quote 0
        • doguibnuD
          doguibnu
          last edited by

          @marcelloc:

          Eu recomendo fortemente olhar a definição do protocolo ftp.

          Já postei várias vezes aqui no fórum sobre isso e o problema cai sempre no entendimento do uso do protocolo.

          O ftp usa a porta 21 para comandos somente.
          No modo ativo, a porta 20 é utilizada no sentido contrário para a transferência de dados.
          No modo passivo, o servidor separa uma faixa de portas para essa transferência no mesmo sentido de comunicação que o cliente fez para acessar a porta 21.

          Estou anexando mais uma vez imagens demonstrando o uso, já que só nesse tópico temos três com dúvidas sobre ftp.

          Marcelo, bom dia tudo bem?

          Não é mais ou menos seguir isso aqui:

          https://doc.pfsense.org/index.php/FTP_without_a_Proxy

          em Server Behind pfSense

          Mesmo você colocando este esquema aí, não consegui entender bem. Já configurei a NAT de várias formas e também o vsftp  está em modo passivo.

          Pelo que entendi, precisa-se ter uma range de portas altas para que possa ser feito a conexão. Mas onde e de que maneira configura-se isso de modo correto.

          Estou algumas semanas tentando configurar isso de modo que funcione, mas nada está dando certo!

          Obrigado pela atenção

          Douglas

          1 Reply Last reply Reply Quote 0
          • marcellocM
            marcelloc
            last edited by

            Se usou a configuração do link, seu servidor de ftp está com essas linhas:

            
            # Do not allow the client to use PORT
            port_enable=NO
            # Use the hostname in the PASV response (DNS must be setup and match!)
            pasv_addr_resolve=YES
            # Enable Passive Mode
            pasv_enable=YES
            # Set the passive port range (1000 ports)
            pasv_min_port=20000
            pasv_max_port=20999
            

            Isso significa que seu nat precisar ter a porta 21 e o range definido no arquivo de configuração.

            Treinamentos de Elite: http://sys-squad.com

            Help a community developer! ;D

            1 Reply Last reply Reply Quote 0
            • C
              claudevan
              last edited by

              marcelloc
              Cara você tem razão!

              As portas 22 (ssh), 443(https) e todas as portas altas de 1024:65000 não faz sentido nesta configuração para esta aplicação. Eu estava testando em casa e só tinha testado de Linux para Linux e como disse ocorria tudo bem, porem ao chegar no trabalho no ambiente corporativo onde tem XP, Win7, Win8 e Linux essas configurações que eu mencionei acima não funciona.

              Solução!

              O marcelloc falou essas palavras acima:

              1_O ftp usa a porta 21 para comandos somente.
              2_No modo ativo, a porta 20 é utilizada no sentido contrário para a transferência de dados.
              3_No modo passivo, o servidor separa uma faixa de portas para essa transferência no mesmo sentido de comunicação que o cliente fez para acessar a porta 21.

              Está correto, é isso mesmo! Então vendo a figura que você postou iten 3 “Modo Passivo” é dessa forma que o vsftpd trabalha, como dito “o servidor separa uma faixa de portas” como pode ver na Figura0 o cliente inicia na porta: 1036 pois o servidor esta definido como “> 1023” no meu caso eu configurei como: 9040 a 9050 e no arquivo vsftpd.conf eu habilitei o modo passivo, segui abaixo a configuração do modo passivo:

              Colocar no fim da linha do arquivo: /etc/vsftpd/vsftpd.conf

              Habilitando o modo passivo.

              pasv_enable=YES
              pasv_address=IPMAQUINA onde esta instalado!
              pasv_max_port=9050
              pasv_min_port=9040

              No firewall pfsense:

              Firewall: Aliases

              Fiz uma "aliases" chamado "Portas_ftp" e nele coloque as seguintes portas: 20, 21, 9040:9050 como segui na Figura1.

              Firewall: NAT: Port Forward

              Liberei uma regra de firewall NAT como segui na Figura2.

              Erro encontrado no Windows:

              O erro que você pode ver na Figura3 é clássica do Windows e eu já mim deparei varias vezes com ele e não soube resolver, "Errro de permissão!" como você pode ver no link essa era uma duvida de um usuário aqui no fórum: “https://forum.pfsense.org/index.php?topic=44733.0” aqui vai a solução no: Windows Explore ou Internet Explore vá em: Ferramentas/Opções da Internet/Avançadas/Navegação e desabilite a opção “Usar FTP Passivo(para compatibilidade com firewall e modem DSL)” olhar Figura4. Gente eu li em vários artigos para deixar essa opção habilitada, mas é o contrario, com ela habilitada vai da o erro da Figura3, testei em varias máquinas aqui na empresa.

              Observação: No Windows8 e em server no “Windowns Explore” não tem a opção Ferrametas.

              Gente aqui na empresa agora tá funcionando normalmente o "ftp" vsftpd tanto internamente como externamente.

              Qualquer duvida posta ai…

              Figura0.jpg
              Figura0.jpg_thumb
              Figura1.jpg
              Figura1.jpg_thumb
              Figura2.jpg
              Figura2.jpg_thumb
              Figura3.jpg
              Figura3.jpg_thumb
              Figura4.jpg
              Figura4.jpg_thumb

              1 Reply Last reply Reply Quote 0
              • doguibnuD
                doguibnu
                last edited by

                Claudevan,
                Tudo bem?

                Na sua empresa vc usa estrutura de MPLS.

                Aqui nós temos rotas para outras "pontas"

                Por exemplo aqui é: 10.1.1.x dentro do pfsense está a rotas para outras pontas: 10.10.6.254, 10.10.4.254 e assim por diante. Então, se eu estou nessas "pontas" e tento conectar o ftp por nosso IP público 200.x.x.x.x, ele até pede a usuário e senha, mas não faz a conexão. Já se estou forma de nossa estrutura, ou seja, qualquer outra rede que não faça parte da nossa rede, ele conecta normalmente via ip público.
                Eu tentarei fazer da forma que você fez pois, já li uns quinhentos foruns e não consigo vencer heuehueheueh.

                Obrigado

                Se obter sucesso eu posto aqui!

                Douglas

                @claudevan:

                marcelloc
                Cara você tem razão!

                As portas 22 (ssh), 443(https) e todas as portas altas de 1024:65000 não faz sentido nesta configuração para esta aplicação. Eu estava testando em casa e só tinha testado de Linux para Linux e como disse ocorria tudo bem, porem ao chegar no trabalho no ambiente corporativo onde tem XP, Win7, Win8 e Linux essas configurações que eu mencionei acima não funciona.

                Solução!

                O marcelloc falou essas palavras acima:

                1_O ftp usa a porta 21 para comandos somente.
                2_No modo ativo, a porta 20 é utilizada no sentido contrário para a transferência de dados.
                3_No modo passivo, o servidor separa uma faixa de portas para essa transferência no mesmo sentido de comunicação que o cliente fez para acessar a porta 21.

                Está correto, é isso mesmo! Então vendo a figura que você postou iten 3 “Modo Passivo” é dessa forma que o vsftpd trabalha, como dito “o servidor separa uma faixa de portas” como pode ver na Figura0 o cliente inicia na porta: 1036 pois o servidor esta definido como “> 1023” no meu caso eu configurei como: 9040 a 9050 e no arquivo vsftpd.conf eu habilitei o modo passivo, segui abaixo a configuração do modo passivo:

                Colocar no fim da linha do arquivo: /etc/vsftpd/vsftpd.conf

                Habilitando o modo passivo.

                pasv_enable=YES
                pasv_address=IPMAQUINA onde esta instalado!
                pasv_max_port=9050
                pasv_min_port=9040

                No firewall pfsense:

                Firewall: Aliases

                Fiz uma "aliases" chamado "Portas_ftp" e nele coloque as seguintes portas: 20, 21, 9040:9050 como segui na Figura1.

                Firewall: NAT: Port Forward

                Liberei uma regra de firewall NAT como segui na Figura2.

                Erro encontrado no Windows:

                O erro que você pode ver na Figura3 é clássica do Windows e eu já mim deparei varias vezes com ele e não soube resolver, "Errro de permissão!" como você pode ver no link essa era uma duvida de um usuário aqui no fórum: “https://forum.pfsense.org/index.php?topic=44733.0” aqui vai a solução no: Windows Explore ou Internet Explore vá em: Ferramentas/Opções da Internet/Avançadas/Navegação e desabilite a opção “Usar FTP Passivo(para compatibilidade com firewall e modem DSL)” olhar Figura4. Gente eu li em vários artigos para deixar essa opção habilitada, mas é o contrario, com ela habilitada vai da o erro da Figura3, testei em varias máquinas aqui na empresa.

                Observação: No Windows8 e em server no “Windowns Explore” não tem a opção Ferrametas.

                Gente aqui na empresa agora tá funcionando normalmente o "ftp" vsftpd tanto internamente como externamente.

                Qualquer duvida posta ai…

                1 Reply Last reply Reply Quote 0
                • C
                  claudevan
                  last edited by

                  doguibnu

                  Cara você de uma dessas pontas: 10.10.6.254 consegui pingar seu IP externo do firewall?

                  Já testou fazer uma conexão remota com o (Terminal Service) de sua casa para a maquina com o IP: 10.10.6.254?

                  Testa fazer uma conexão remota primeiro, se não souber diz que te passo como faz, e vai testando, se precisar de ajuda posta ai.

                  1 Reply Last reply Reply Quote 0
                  • doguibnuD
                    doguibnu
                    last edited by

                    @claudevan:

                    doguibnu

                    Cara você de uma dessas pontas: 10.10.6.254 consegui pingar seu IP externo do firewall?

                    Já testou fazer uma conexão remota com o (Terminal Service) de sua casa para a maquina com o IP: 10.10.6.254?

                    Testa fazer uma conexão remota primeiro, se não souber diz que te passo como faz, e vai testando, se precisar de ajuda posta ai.

                    Claudevan, tudo bem?

                    Respondendo suas perguntas

                    1 - sim as pontas pingam o para o ip externo do firewall
                    2- Sim, já foi feito conexão remota de outra ponta normalmente, assim como teamviewer.

                    Configurei o Pfsense do jeito que você sugeriu e…não funcionou.

                    Coisa triste mesmo!

                    Obrigado por enquanto!

                    Douglas

                    1 Reply Last reply Reply Quote 0
                    • doguibnuD
                      doguibnu
                      last edited by

                      Bom dia Pessoal!
                      Tudo bem?

                      Bom, segui a sugestão de configuração do Claudevan. Ainda não tive sucesso porém, parece que falta alguma coisa pra ser liberado. Vejam o que diz o Log do Filezila, está conectando 99,99 porcento:

                      Alguém teria uma luz:

                      Estado: Conectando 200.x.x.x
                      Estado: Conexão estabelecida, esperando mensagem de boas-vindas…
                      Resposta: 220 FTP Server
                      Comando: USER ftpuser
                      Resposta: 331 Please specify the password.
                      Comando: PASS *******
                      Resposta: 230 Login successful.
                      Comando: SYST
                      Resposta: 215 UNIX Type: L8
                      Comando: FEAT
                      Resposta: 211-Features:
                      Resposta: EPRT
                      Resposta: EPSV
                      Resposta: MDTM
                      Resposta: PASV
                      Resposta: REST STREAM
                      Resposta: SIZE
                      Resposta: TVFS
                      Resposta: UTF8
                      Resposta: 211 End
                      Comando: OPTS UTF8 ON
                      Resposta: 200 Always in UTF8 mode.
                      Estado: Conectado
                      Estado: Obtendo lista de pastas...
                      Comando: PWD
                      Resposta: 257 "/"
                      Comando: TYPE I
                      Resposta: 200 Switching to Binary mode.
                      Comando: PASV
                      Erro: A conexão excedeu limite de tempo
                      Erro: Falha na obtenção da lista de pastas

                      Muito Obrigado e fiquem com Deus

                      Douglas

                      1 Reply Last reply Reply Quote 0
                      • marcellocM
                        marcelloc
                        last edited by

                        doguibnu, Monitore o trafego dessa conexão no firewall. Você tem que ver conexões além da porta 21. Se for no modo passivo, uma porta alta.

                        Treinamentos de Elite: http://sys-squad.com

                        Help a community developer! ;D

                        1 Reply Last reply Reply Quote 0
                        • doguibnuD
                          doguibnu
                          last edited by

                          @marcelloc:

                          doguibnu, Monitore o trafego dessa conexão no firewall. Você tem que ver conexões além da porta 21. Se for no modo passivo, uma porta alta.

                          Marcello, eu vi o seu post em para um gringo e pedindo pro cara dar uma olhada nesse link: http://slacksite.com/other/ftp.html#pasvexample

                          Eu estou estudando e tentando segui-lo. Percebi que em modo passivo ele abre mais do que a porta 21 e pelo que vi a 20 nem é usada. Já configurei o vsftp em modo passivo, assim como fiz as Nat para as portas altas (no caso 20000 e 20999), mas ainda estou apanhando em algo que está faltando pra ele realmente concretizar a conexão!

                          Bom, vou continuar estudando o devido protocolo ftp!

                          Obrigado por enquanto!

                          1 Reply Last reply Reply Quote 0
                          • doguibnuD
                            doguibnu
                            last edited by

                            Pessoal e Marcello, Bom dia!

                            Bom, nessa última semana passei estudando como configurar o FTP vsftp em modo passivo pois, o servidor de ftp está atrás do pfsense.
                            Então, visto que o modo passivo não usa somente a porta 21 e 20 e sim, portas altas a partir de 1023, e quando o protocolo ftp abre essa conexão ela usa essas portas.

                            Certo, é necessário que façamos alterações no arquivo vsftpd.conf e façamos com que ele mude a forma de conexão para modo passivo ou seja, pasv:

                            port_enable=YES

                            connect_from_port_20=YES

                            OBS: no nosso caso tivemos que deixar dessa forma se não nem o início da conexão ele consegue iniciar!

                            pasv_enable=YES
                            pasv_address=ip servidor (lan)
                            pasv_max_port=4244
                            pasv_min_port=4243

                            Certo, após isso. Configuramos a NAT no Pfsense.

                            E quando tentamos conectar via filezila:

                            Estado: Conectando 200.x.x.x.
                            Estado: Conexão estabelecida, esperando mensagem de boas-vindas…
                            Resposta: 220 FTP Server
                            Comando: USER ftpuser
                            Resposta: 331 Please specify the password.
                            Comando: PASS *******
                            Resposta: 230 Login successful.
                            Comando: OPTS UTF8 ON
                            Resposta: 200 Always in UTF8 mode.
                            Estado: Conectado
                            Estado: Obtendo lista de pastas...
                            Comando: PWD
                            Resposta: 257 "/"
                            Comando: TYPE I
                            Resposta: 200 Switching to Binary mode.
                            Comando: PASV
                            Erro: A conexão excedeu limite de tempo
                            Erro: Falha na obtenção da lista de pastas

                            Verificando outros foruns e blogs. O que pude constatar é que grande parte dos administradores abriram estas portas altas a partir do iptables e assim garantiram a conexão efetiva para seu servidor de ftp em modo passivo, como neste link:

                            http://ifzenelse.net/en/install-and-configure-your-very-secure-ftp-vsftp-server-centos-linux

                            ou

                            http://lost-and-found-narihiro.blogspot.com.br/2014/03/ubuntu-1310-vsftpd-passive-activeport.html

                            Fora outros mais que foram pesquisados e que de certa forma, todos liberavam acesso a essas portas.

                            Creio que é isso que falta fazer dentro do pfsense. Mas de que forma libero estas portas se já foram feitas uma Nat para elas juntamente com o aliases e lá dentro em Ports especificado as portas altas?

                            Marcello, de que forma posso monitorar o tráfego da conexão?

                            Eu acredito que este é o único detalhe que resta para que a conexão seja efetivamente feita.

                            Muito obrigado

                            Att

                            Douglas

                            1 Reply Last reply Reply Quote 0
                            • doguibnuD
                              doguibnu
                              last edited by

                              Olá Claudevan e Marcello

                              Eu mudei de servidor ftp, e passei a usar o Proftpd. Está configurado em modo passivo da forma que você sugeriu aqui.
                              No filezilla ele conectou uma maravilha com o ip público. Deu certo.
                              Mas nos navegadores, nem no firefox e nem no chrome tive sucesso.

                              Alguma sugestão?

                              Muito Obrigado!

                              Douglas

                              @claudevan:

                              marcelloc
                              Cara você tem razão!

                              As portas 22 (ssh), 443(https) e todas as portas altas de 1024:65000 não faz sentido nesta configuração para esta aplicação. Eu estava testando em casa e só tinha testado de Linux para Linux e como disse ocorria tudo bem, porem ao chegar no trabalho no ambiente corporativo onde tem XP, Win7, Win8 e Linux essas configurações que eu mencionei acima não funciona.

                              Solução!

                              O marcelloc falou essas palavras acima:

                              1_O ftp usa a porta 21 para comandos somente.
                              2_No modo ativo, a porta 20 é utilizada no sentido contrário para a transferência de dados.
                              3_No modo passivo, o servidor separa uma faixa de portas para essa transferência no mesmo sentido de comunicação que o cliente fez para acessar a porta 21.

                              Está correto, é isso mesmo! Então vendo a figura que você postou iten 3 “Modo Passivo” é dessa forma que o vsftpd trabalha, como dito “o servidor separa uma faixa de portas” como pode ver na Figura0 o cliente inicia na porta: 1036 pois o servidor esta definido como “> 1023” no meu caso eu configurei como: 9040 a 9050 e no arquivo vsftpd.conf eu habilitei o modo passivo, segui abaixo a configuração do modo passivo:

                              Colocar no fim da linha do arquivo: /etc/vsftpd/vsftpd.conf

                              Habilitando o modo passivo.

                              pasv_enable=YES
                              pasv_address=IPMAQUINA onde esta instalado!
                              pasv_max_port=9050
                              pasv_min_port=9040

                              No firewall pfsense:

                              Firewall: Aliases

                              Fiz uma "aliases" chamado "Portas_ftp" e nele coloque as seguintes portas: 20, 21, 9040:9050 como segui na Figura1.

                              Firewall: NAT: Port Forward

                              Liberei uma regra de firewall NAT como segui na Figura2.

                              Erro encontrado no Windows:

                              O erro que você pode ver na Figura3 é clássica do Windows e eu já mim deparei varias vezes com ele e não soube resolver, "Errro de permissão!" como você pode ver no link essa era uma duvida de um usuário aqui no fórum: “https://forum.pfsense.org/index.php?topic=44733.0” aqui vai a solução no: Windows Explore ou Internet Explore vá em: Ferramentas/Opções da Internet/Avançadas/Navegação e desabilite a opção “Usar FTP Passivo(para compatibilidade com firewall e modem DSL)” olhar Figura4. Gente eu li em vários artigos para deixar essa opção habilitada, mas é o contrario, com ela habilitada vai da o erro da Figura3, testei em varias máquinas aqui na empresa.

                              Observação: No Windows8 e em server no “Windowns Explore” não tem a opção Ferrametas.

                              Gente aqui na empresa agora tá funcionando normalmente o "ftp" vsftpd tanto internamente como externamente.

                              Qualquer duvida posta ai…

                              1 Reply Last reply Reply Quote 0
                              • First post
                                Last post
                              Copyright 2025 Rubicon Communications LLC (Netgate). All rights reserved.