Chinaunix首页 | 论坛 | 博客
  • 博客访问: 850645
  • 博文数量: 436
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: -103
  • 用 户 组: 普通用户
  • 注册时间: 2016-08-01 09:48
个人简介

爱生活,爱IT

文章分类

全部博文(436)

文章存档

2015年(1)

2014年(2)

2013年(6)

2011年(39)

2010年(176)

2009年(30)

2008年(28)

2007年(54)

2006年(91)

2005年(9)

分类: LINUX

2009-01-06 14:03:21

一、测试平台
Debian 4.0r3
Proftpd 1.3.1 (WITH SSL)

二、原理简介
1、 继承性
    子目录会继承其父目录的属性。
2、 优先级
    优先级由大到小的顺序:
    原始FTP命令(LIST  DELE等)  >  命令组(DIRS  READ  WRITE)  >  ALL命令组
3、 访问控制的应用顺序
    不论出现顺序如何,先应用拒绝(Deny),后应用允许(Allow)
4、系统权限
    Linux系统权限仍然起作用。如果设置了目录test的允许写,但是该用户对test目录只有
    读权限,这是该用户就不能向test目录写入。


      ----------------- 1、继承性
             ------------------------- 2、优先级
          AllowUser  u1          -------------------- 3、访问控制的应用顺序
          DenyAll
     



    一点解释:根据参考1所述,访问控制的顺序应该是与其出现顺序有关,但是在我的测试中发现出现顺序没有什么影响。也就是说,像上面的访问控制,AllowUser u1和DenyAll哪个在前面都一样。
 
三、实例
1、简介
假设proftpd服务器上有5个用户:
        manager, manA1, manA2, manB1, manB2
和2个组:
        groupA, groupB
manA1和manA2属于groupA组,manB1和manB2属于groupB组。
并且有如下目录结构:
    /根目录
    │
    ├ftproot/      
    │       ├manager/
    │       │
    │       ├groupA/
    │       │      ├A1/
    │       │      ├A2/
    │       │      └.../
    │       │
    │       ├groupB/
    │              ├B1/
    │              ├B2/
    │              └.../
    │
    └.../
现在要实现的权限:
1、用户manager可以读写manager、groupA、groupB目录及它们的的子目录。
2、manA1可以读写A1目录,并且可以读写groupB的所有子目录。
3、manA2可以读写A2目录,并且可以读写groupB的所有子目录。
4、manB1可以读写B1目录。
5、manB2可以读写B2目录。
6、如果一个用户没有某个目录的访问权限,那么该用户就不能看到此目录。
7、只允许manger用户和groupA、groupB组成员访问FTP服务器。
8、不允许任何人破坏主干目录结构

2、实现

(1)添加用户和组        

        useradd manager
        passwd manager
        groupadd groupA
        groupadd groupB
        useradd manA1
        passwd manA1
        usermod -G groupA manA1
        useradd manA2
        passwd manA2
        usermod -G groupA manA2
        useradd manB1
        passwd manB1
        usermod -G groupB manB1
        useradd manB2
        passwd manB2
        usermod -G groupB manB2

(2)配置文件
# This is a basic ProFTPD configuration file (rename it to
# 'proftpd.conf' for actual use.  It establishes a single server
# and a single anonymous login.  It assumes that you have a user/group
# "nobody" and "ftp" for normal operation and anon.
ServerName   "Formax BPO FTP Server"
ServerType   standalone
DefaultServer   on
# Port 21 is the standard FTP port.
Port    21
UseReverseDNS off
IdentLookups off# Umask 022 is a good standard umask to prevent new dirs and files
# from being group and world writable.
Umask    000
# 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
# Set the user and group under which the server will run.
User    nobody
Group    nogroup
# To cause every FTP user to be "jailed" (chrooted) into their home
# directory, uncomment this line.
# DefaultRoot ~
DefaultRoot /ftproot
# Normally, we want files to be overwriteable.
AllowOverwrite  on
AllowStoreRestart on
ServerIdent off

mod_tls.c>
      TLSEngine on
      TLSLog /var/ftpd/tls.log
      TLSProtocol SSLv23
      # Are clients required to use FTP over TLS when talking to this server?
      TLSRequired on
      # Server's certificate
      TLSRSACertificateFile /etc/proftpd.cert
      TLSRSACertificateKeyFile /etc/proftpd.key
      # CA the server trusts
      TLSCACertificateFile /etc/proftpd.cert
      # Authenticate clients that want to use FTP over TLS?
      TLSVerifyClient off
      TLSOptions NoCertRequest
      # Allow SSL/TLS renegotiations when the client requests them, but
      # do not force the renegotations.  Some clients do not support
      # SSL/TLS renegotiations; when mod_tls forces a renegotiation, these
      # clients will close the data connection, or there will be a timeout
      # on an idle data connection.
      TLSRenegotiate required off
# Bar use of SITE CHMOD by default
SITE_CHMOD>
      DenyAll
LOGIN>
      AllowUser manager
      AllowGroup groupA
      DenyAll
      AllowGroup groupB


/ftproot/*>
     
          DenyAll
     


/ftproot/manager>
     
          AllowUser manager
     


/ftproot/groupA>
     
          AllowUser manager
          AllowGroup groupA
     


/ftproot/groupA/*>
     
          DenyAll
     


/ftproot/groupA/A2>
     
          AllowUser manager
          AllowUser manA2
          DenyAll
     


/ftproot/groupA/A1>
     
          AllowUser manager
          AllowUser manA1
          DenyAll
     


/ftproot/groupB>
     
          AllowUser manager
          AllowGroup groupA
          AllowGroup groupB
     


/ftproot/groupB/*>
     
          DenyAll
     


/ftproot/groupB/B1>
     
          AllowUser manager
          AllowUser manB1
          AllowGroup groupA
          DenyAll
     


/ftproot/groupB/B2>
     
          AllowUser manager
          AllowUser manB2
          AllowGroup groupA
     


参考:
1、
2、
3、

本文出自 “GONE WITH THE WIND” 博客,请务必保留此出处http://h2appy.blog.51cto.com/609721/123997

 

----博主补充错误解决!

1, IPV6 出错:

How to I completely disable (or remove) IPv6 from my slackware box? I'm using 10.1 atm.

在/etc/modprobe.conf 加上 alias net-pf-10 off

2,proftpd不能正常啟動 Starting proftpd: localhost.localdomain - error converting stdin to IPv6 socket: Socket operation on non-socket
localhost.localdomain - fatal: Socket operation on non-socket

解决: 設成 inetd, 那麼 proftpd 就是由 inetd/xinetd 啟動.
若要手動執行 proftpd, 要把 ServerType 設成 standalone 才行.


 

 

精典收藏:SQL Server 2008 集群+SAN集成方案:
  • 精典收藏:中小型IT机房UPS不间断电力解决方案:
  • 阅读(1588) | 评论(0) | 转发(0) |
    给主人留下些什么吧!~~