Kirjoittaja Aihe: ProFTP ja porttimääritys  (Luettu 3810 kertaa)

EeroL

  • Käyttäjä
  • Viestejä: 57
    • Profiili
ProFTP ja porttimääritys
« : 19.10.11 - klo:20.39 »
Loin pienen ohjeen itselleni miten saan näppärästi proftp:n toimii.
Tuli yksi mutta eteen eli määritin portiksi 2121.
Se toimi sisäverkossa hienosti, mutta kun kokeilin ulkoverkosta, niin kirjautuminen ei enää  onnistunut.
Muutin portin takaisin 21:ksi ja taas pelittää ulkoverkostakin.

Mikä on pielessä porttia lukuunottamatta alla olevassa konffissa?

Miten saan ulkoverkonkin ymmärtämään porttia 2121?

Koodia: [Valitse]
#
#
# Perusasetukset. Kaksi käyttäjää joiden kotihakemisto on /home/FTP-jako
# Käyttäjällä theboss on kaikki oikeudet kaikkialle
# Käyttäjällä mavaan on vain latausoikeus download-kansiosta ja
# saa ladata tiedostoja upload-kansioon
# porttina käytetään 2121
# /etc/proftpd/proftpd.conf -- ProFTPD asetustiedosto.
#
# Ja näin se tapahtuu
# Asennetaan
#  sudo apt-get install proftpd
# Lisätään
#  sudo gedit /etc/shells
# rivi
#  /bin/false
# Luodaan FTP-jako hakemisto
#   cd /home
#   sudo mkdir FTP-jako
# Luodaan niiden alle download- ja upload-hakemistot
#   cd /home/FTP-jako/
#   sudo mkdir download
#   sudo mkdir upload
# Annetaan hakemisto-oikeudet
#   cd /home
#   sudo chmod 755 FTP-jako
#   cd FTP-jako
#   sudo chmod 777 download
#   sudo chmod 777 upload
# Kopioidaan tämä ja annetaan komento
#   sudo gedit /etc/proftpd/proftpd.conf
# ja liitetetään
# Luodaan käyttäjät theboss ja mavaan
#   sudo useradd theboss -p thebosssalasana -d /home/FTP-jako -s /bin/false
#   sudo useradd mavaan -p mavaansalasana -d /home/FTP-jako -s /bin/false
# Annetaan salasanat käyttäjille
#   sudo passwd theboss -> salasana kahdesti
#   sudo passwd mavaan -> salasana kahdesti
# Käynnistetään FTP uusiksi
#   sudo /etc/init.d/proftpd restart
#
# Ja vapaa ajattelu on sallittua nimien ym. osalta ;-)
#

# Includes DSO modules
Include /etc/proftpd/modules.conf

# Set off to disable IPv6 support which is annoying on IPv4 only boxes.
# Poistetaan IPv6 käytöstä. Ei tarvita vielä.
UseIPv6 off
# If set on you can experience a longer connection delay in many cases.
IdentLookups off

ServerName "Eeron FTP"
ServerType standalone
DeferWelcome on

MultilineRFC2228 on
DefaultServer on
ShowSymlinks on

TimeoutNoTransfer 600
TimeoutStalled 600
TimeoutIdle 1200

DisplayLogin                    welcome.msg
DisplayChdir                .message true
ListOptions                "-l"

DenyFilter \*.*/


# Set /home/FTP-shared directory as home directory
DefaultRoot /home/FTP-jako

# Use this to jail all users in their homes
# Estetään käyttäjän pääsy muuhun kuin kotihakemistoonsa, ***** TOSI TÄRKEÄ *****
DefaultRoot ~

# Näytetään onnistuneesta kirjautumisesta viesti
AccessGrantMsg "Tervetuloa !!!"
# Tämä näytetään ennen kirjautumista
ServerIdent                  on       "Odotetaan tunnistautumista"


# Kenen sallitaan kirjautua
# Kun lisäät uuden käyttäjän se pitää lisätä myös tähän
<Limit LOGIN>
AllowUser mavaan
AllowUser theboss
DenyALL
</Limit>

## Määritetään hakemisto-oikeudet

<Directory /home/FTP-jako>
Umask 022 022
AllowOverwrite off
<Limit MKD STOR DELE XMKD RNRF RNTO RMD XRMD>
AllowUser theboss
DenyAll
</Limit>
</Directory>

 <Directory /home/FTP-jako/download/*>
 Umask 022 022
 AllowOverwrite off
<Limit MKD STOR DELE XMKD RNEF RNTO RMD XRMD>
AllowUser theboss
DenyAll
</Limit>
 </Directory>

 <Directory> /home/FTP-jako/upload/>
 Umask 022 022
 AllowOverwrite on
<Limit READ RMD DELE>
AllowUser theboss
      DenyAll
    </Limit>

    <Limit STOR CWD MKD>
      AllowAll
    </Limit>
 </Directory>

##### Hakemistomääritykset päättyy ######

# FTP:n käyttämä portti. 21 on oletus.
# Turvallisuuden vuoksi kannattaa käyttää muuta
Port 21

# Users require a valid shell listed in /etc/shells to login.
# Use this directive to release that constrain.
# RequireValidShell off

# In some cases you have to specify passive ports range to by-pass
# firewall limitations. Ephemeral ports can be used for that, but
# feel free to use a more narrow range.
# PassivePorts                  49152 65534

# If your host was NATted, this option is useful in order to
# allow passive tranfers to work. You have to use your public
# address and opening the passive ports used on your firewall as well.
# MasqueradeAddress 84.249.126.176

# This is useful for masquerading address with dynamic IPs:
# refresh any configured MasqueradeAddress directives every 8 hours
<IfModule mod_dynmasq.c>
# DynMasqRefresh 28800
</IfModule>

# To prevent DoS attacks, set the maximum number of child processes
# to 30.  If you need to allow more than 30 concurrent connections
# at once, simply increase this value.  Note that this ONLY works
# in standalone mode, in inetd mode you should use an inetd server
# that allows you to limit maximum number of processes per service
# (such as xinetd)
MaxInstances 30

# Asetetaan käyttäjä ja ryhmä jotka käyttää palvelua
User proftpd
Group nogroup

# Umask 022 is a good standard umask to prevent new files and dirs
# (second parm) from being group and world writable.
Umask 022  022
# Normally, we want files to be overwriteable.
AllowOverwrite on

# Uncomment this if you are using NIS or LDAP via NSS to retrieve passwords:
# PersistentPasswd off

# This is required to use both PAM-based authentication and local passwords
# AuthOrder mod_auth_pam.c* mod_auth_unix.c

# Be warned: use of this directive impacts CPU average load!
# Uncomment this if you like to see progress and transfer rate with ftpwho
# in downloads. That is not needed for uploads rates.
#
# UseSendFile off

TransferLog /var/log/proftpd/xferlog
SystemLog   /var/log/proftpd/proftpd.log

<IfModule mod_quotatab.c>
QuotaEngine off
</IfModule>

<IfModule mod_ratio.c>
Ratios off
</IfModule>


# Delay engine reduces impact of the so-called Timing Attack described in
# http://security.lss.hr/index.php?page=details&ID=LSS-2004-10-02
# It is on by default.
<IfModule mod_delay.c>
DelayEngine on
</IfModule>

<IfModule mod_ctrls.c>
ControlsEngine        off
ControlsMaxClients    2
ControlsLog           /var/log/proftpd/controls.log
ControlsInterval      5
ControlsSocket        /var/run/proftpd/proftpd.sock
</IfModule>

<IfModule mod_ctrls_admin.c>
AdminControlsEngine off
</IfModule>

#
# Alternative authentication frameworks
#
#Include /etc/proftpd/ldap.conf
#Include /etc/proftpd/sql.conf

#
# This is used for FTPS connections
#
#Include /etc/proftpd/tls.conf

# Jos haluaa käyttää anonymous-tiliä niin poista alta kommentti-merkit.

# <Anonymous ~ftp>
#   User ftp
#   Group nogroup
#   # We want clients to be able to login with "anonymous" as well as "ftp"
#   UserAlias anonymous ftp
#   # Cosmetic changes, all files belongs to ftp user
#   DirFakeUser on ftp
#   DirFakeGroup on ftp
#
#   RequireValidShell off
#
#   # Limit the maximum number of anonymous logins
#   MaxClients 10
#
#   # We want 'welcome.msg' displayed at login, and '.message' displayed
#   # in each newly chdired directory.
#   DisplayLogin welcome.msg
#   DisplayChdir .message
#
#   # Limit WRITE everywhere in the anonymous chroot
#   <Directory *>
#     <Limit WRITE>
#       DenyAll
#     </Limit>
#   </Directory>
#
#   # Uncomment this if you're brave.
#   # <Directory incoming>
#   #   # Umask 022 is a good standard umask to prevent new files and dirs
#   #   # (second parm) from being group and world writable.
#   #   Umask 022  022
#   #            <Limit READ WRITE>
#   #            DenyAll
#   #            </Limit>
#   #            <Limit STOR>
#   #            AllowAll
#   #            </Limit>
#   # </Directory>
#
# </Anonymous>

910

  • Käyttäjä
  • Viestejä: 96
    • Profiili
Vs: ProFTP ja porttimääritys
« Vastaus #1 : 20.10.11 - klo:11.15 »
Jos tuo kerran sisäverkosta toimii (muualtakin kuin samalta koneelta), niin ongelma on luultavasti muualla kuin FTP-palvelimen asetuksissa.

Onko ulkoverkon ja FTP-palvelimen välillä palomuuria tai porttiohjauksella varustettua NAT-toiminnallisuutta? Jos on, muuttunut portti on tietysti huomioitava myös näissä.

EeroL

  • Käyttäjä
  • Viestejä: 57
    • Profiili
Vs: ProFTP ja porttimääritys
« Vastaus #2 : 22.10.11 - klo:12.10 »
Kiitos vastauksesta.
Niin mäkin ensin ajattelin. Jos määritän ProFtpd:n porttiin 21 niin kaikki toimii ulkoverkosta. Palomuurista silloin auki portit 20 ja 21. Kun muutan portiksi 2121 ja avaan palomuurista portit 2120 ja 2121 (2120 varmuuden vuoksi) niin saan seuraavan vastauksen ulkoverkosta:

Koodia: [Valitse]
Tila: Yhdistetään kohteeseen 84.249.xxx.xxx:2121...

Tila: Yhteys muodostettu, odotetaan tervetulosanomaa...

Vastaus: 220 Odotetaan tunnistautumista

Komento: USER theboss

Vastaus: 331 Password required for theboss

Komento: PASS ****

Vastaus: 230 Tervetuloa !!!

Komento: SYST

Vastaus: 215 UNIX Type: L8

Komento: FEAT

Vastaus: 211-Features:

Vastaus: MDTM

Vastaus: MFMT

Vastaus: UTF8

Vastaus: MFF modify;UNIX.group;UNIX.mode;

Vastaus: MLST modify*;perm*;size*;type*;unique*;UNIX.group*;UNIX.mode*;UNIX.owner*;

Vastaus: REST STREAM

Vastaus: LANG fi-FI.UTF-8*

Vastaus: SIZE

Vastaus: 211 End

Komento: OPTS UTF8 ON

Vastaus: 200 UTF8 set to on

Tila: Yhdistetty

Tila: Haetaan hakemistolistausta...

Komento: PWD

Vastaus: 257 "/" is the current directory

Komento: TYPE I

Vastaus: 200 Type set to I

Komento: PASV

Vastaus: 227 Entering Passive Mode (192,168,0,33,168,149).

Tila: Palvelin lähetti passiivisen vastauksen osoitteesta, jota ei voi reitittää. Käytetään palvelimen osoitetta.

Komento: MLSD

Virhe: Yhteyden aikakatkaisu

Virhe: Hakemistolistauksen haku epäonnistui

Sisäverkon koneen osoite on siis 192.168.0.33. Ulkoverkon verkko-osoitteen ja koneosoitteen sensuroin.
Musta on vähän outoa että se näyttää sisäverkon ip-osoitteen ftp-clientille.
Palomuurista Wan:sta Lan:iin 2120 ja 2121 auki.
Nat portit 2120 ja 2121 ohjataan osoitteeseen 192.168.0.33

Mun mielestä palomuurin asetukset on kunnossa vai pitääkö jotain kikkailla?

910

  • Käyttäjä
  • Viestejä: 96
    • Profiili
Vs: ProFTP ja porttimääritys
« Vastaus #3 : 24.10.11 - klo:15.30 »
Näyttää siltä, että kontrolliyhteys muodostuu (pääset esim. kirjautumaan), mutta datayhteyttä ei (et näe hakemistolistausta).

Jos nyt joku valistunut arvaus pitäisi heittää, niin arvaan, että käyttäessäsi oletusporttia 21, palomuuri osaa tulkita myös tuon dataliikenteen kuuluvaksi samaan FTP-istuntoon kuin porttiin 21 suuntautuva kontrolliliikenne, kun taas muutetulla portilla palomuuri estääkin dataliikenteen. Jos näin on, dataliikenne on erikseen sallittava. Portit näet/voit säätää FTP-palvelimen konfiguraation kohdasta "PassivePorts".

FTP-protokollan toimintaan tietoliikennetasolla voi tutustua vaikkapa osoitteessa http://slacksite.com/other/ftp.html. Kannattaa huomata, että erikseen on olemassa aktiivi- ja passiivimuotoiset FTP-yhteystavat, joista käytät näköjään tuota passiivista.

 
Lainaus
Musta on vähän outoa että se näyttää sisäverkon ip-osoitteen ftp-clientille.

Mistäpä se palvelin muusta tietäisi, ellei sille erikseen kerrota muuta osoitetta. Osoitteen voi näköjään kertoa konfiguraation rivillä "MasqueradeAddress". Antamasi tulosteen

Lainaus
Tila:   Palvelin lähetti passiivisen vastauksen osoitteesta, jota ei voi reitittää. Käytetään palvelimen osoitetta.

perusteella voisi kylläkin olettaa, että client-sovelluksesi huomaa, ettei osotie ole internetissä reititettävä ja osaa käyttää sitä osoitetta, jolla palvelimeen on otettu yhteys. Voihan tuohon silti kokeilla ulkoverkon osoitetta.

odysseus

  • Vieras
Vs: ProFTP ja porttimääritys
« Vastaus #4 : 24.10.11 - klo:19.29 »
Eikös tuo nyt ole selvä homma:

Jos kyseessä on oma ADSL-vetoinen "ulkoverkko", niin SUA-ohjaus on sekaisin reitittimellä tai sitten koneesi palomuuri estää portin käytön (toivottavasti). Vaihtoehtoisesti client ei älyä, että käytät jotain toista (epästandardia) porttinumeroa.

Mutt miksi _hel****ssä_ pitäisi alkaa käyttämään jotain epästandardia porttia? Saat siitä ennenpitkää (ansaitusti) ongelmia joihin (ansaitusti) et saa apua.

Pysykää hyvät ihmiset nyt niissä määrittelyissä mitkä ovat standardeja tai "de-facto"!!!! Käytä porttia 21 kun kerran protokolla on FTP!!