分享
 
 
 

Debian+vsftpd+MySQL实现虚拟用户

王朝mysql·作者佚名  2008-05-21
窄屏简体版  字體: |||超大  

一,需求

1,虚拟用户登录

由于之前配置成功了postfix+MySQL虚拟用户登录,体会到了使用虚拟用户的好处和灵活性,所以

这次也考虑采用虚拟用户,并且将FTP虚拟用户的信息也存储在MySQL中,这样以后用PHP等写一些

WEB GUI的管理程序,统一管理用户,还是蛮方便的.

2,限制IP的匿名登录

开放匿名登录,但是只允许特定的IP可以匿名登录

3,不同用户,不同目录,不同权限

听起来有点像绕口令吧,举例来说,有2个用户,分别是普通用户(normal)和管理员(admin),FTP有2个

目录,分别是incoming和pub,要实现如下权限设置:

incoming pub

normal 读/写 只读

admin 读/写 读/写

4,通过FTP管理Web站点

服务器上还架设了Apache,而网站管理员对Linux又不是很熟悉,而且也不想开放一个帐号给

网站管理员,以免他登录到系统上去,把系统搞的乱78糟,所以参考Internet上提供虚拟主机的流行做法,

就是通过FTP来管理网站,所以需要提供一个可供网站管理员登录FTP进行网站管理的帐号.

5,扩展功能

待定..

二,选择FTP服务器软件

Linux 下架设FTP站点,有很多优秀的FTP服务器软件可供选择,例如Wu-FTPD,Pure-FTPD,ProFTPD以及vsFTPD等等,要想选择一个 适合自己需求的FTP服务器软件,也需要费点脑筋才行,对于我来说,选择 vsftpd(very secure FTP daemon),主要有以下两 点原因:

1,选择原则一

有人说,哪个FTPD是你最熟悉的就用哪个,不过由于我之前没有在Linux下架设FTP站点的经验,所以,对我来说,一切都是新的起点.在vsftpd的官方主页上看到了Debian官方FTP,RH官方FTP等都使用了vsftpd,于是"随波逐流"吧,这样看起来会有面子些~

2,选择原则二

第二点很大程度取决于vsftpd(very secure FTP daemon)的名字,因为它是很安全的FTP软件嘛,哈哈,再说Debian官方等FTP都使用了vsftpd,选择它应该没错的~

PS:FTP服务器软件的选择可以参考"鸟哥的Linux私房菜中的简易vsftpd服务器架设"一文.

三,实现

基于Debian GNU/Linux 3.1 Sarge 和 vsftpd-2.0.3

1,需要的软件包

1),vsftpd

very secure FTP daemon

2),mysql-server,mysql-client

前者是MySQL数据库服务器,用于存储虚拟用户信息,后者提供一个命令行的MySQL Client. 由于我之前配置postfix时,已经安装过了MySQL,所以我不必安装这个包了^_^

3),libpam-mysql

vsftpd是通过PAM验证用户信息的,这个包可以让PAM去读取MySQL完成验证.

2,安装

以root登录Debian,输入以下命令,搞定~

#apt-get install vsftpd,libpam-mysql

3,创建一个必要的本地用户

虽说是虚拟用户,不过,由于虚拟用户的信息存储在MySQL数据库中,所以还是需要一个能够读取

MySQL数据库的本地用户.

1),创建本地用户的家目录,此目录也是FTP的家目录

#mkdir /home/ftp

2),创建名为ftpguest的本地用户

#useradd ftpguest -d /home/ftp

3),修改FTP家目录的所有者和组

#chown ftpguest.nogroup /home/ftp

4,配置MySQL数据库

1),创建用于存储虚拟用户信息的数据库ftpvuser

#mysqladmin -u root -p create ftpvuser

2),连接数据库

#mysql -u root -p

3)创建用于存储虚拟用户信息的表users

mysql>use ftpvuser;

mysql>CREATE TABLE users (username varchar(20) NOT NULL,password varchar(40) NOT NULL,PRIMARY KEY (username)) TYPE=MyISAM;

4)让本地用户ftpguest能读取ftpvuser数据库的users表的内容

注:YourPassword用于设定ftpguest访问数据库的密码.

mysql>grant select on ftpvuser.users to ftpguest@localhost identified by 'YourPassword';

mysql>flush privileges;

5),建立虚拟用户

mysql>insert into users (username,password) values ('normal','555555');

mysql>insert into users (username,password) values ('admin','666666');

mysql>insert into users (username,password) values ('webmaster','777777');

6),完成MySQL的配置

mysql>quit;

5,配置vsftpd的PAM验证

1),打开PAM配置文件

#nano /etc/pam.d/vsftpd

2),将以前的内容注释掉,然后添加下面2行内容

注:YourPassword就是刚才在前面设定的ftpguest访问数据库的密码.

auth required pam_mysql.so user=ftpguest passwd=YourPassword host=localhost db=ftpvuser table=users usercolumn=username passwdcolumn=password crypt=0

account required pam_mysql.so user=ftpguest passwd=YourPassword host=localhost db=ftpvuser table=users usercolumn=username passwdcolumn=password crypt=0

6,配置vsftpd

1),打开vsftpd的配置文件

#nano /etc/vsftpd.conf

注意:一旦修改了/etc/vsftpd.conf文件的内容,必须重启vsftpd才能使新的设置生效,方法是:

#/etc/init.d/vsftpd stop

#/etc/init.d/vsftpd start

直接#/etc/init.d/vsftpd restart,好像不起作用?

2),修改vsftpd.conf文件如下

#关闭匿名用户访问

#anonymous_enable=YES

#开启本地用户访问

local_enable=YES

#开启虚拟用户访问

guest_enable=YES

guest_username=ftpguest

#将本地用户限制在自己的家目录,这样可避免FTP用户访问到其他的系统目录

chroot_local_user=YES

3),500 OOPS: cap_set_proc

赶快登录FTP试一下吧,不过为什么无法登录呢?服务器返回错误:500 OOPS: cap_set_proc

Google之,这个错误似乎与SELinux有关,解决办法是加载capability模块:

#modprobe capability

为了让Linux在启动时自动加载此模块,把这个模块放到/etc/modules中即可.

4),限制IP的匿名登录

要想限制登录vsftpd的客户端的IP地址,要用到一个叫TCP Wrappers的东东,对于TCP Wrappers,

我的理解是,如果在vsftpd中启用了TCP Wrappers的话,每次客户端向vsftpd发起一个连接请求的时候,

vsftpd首先会把这个连接请求交给TCP Wrappers处理,如果客户端的IP被TCP Wrappers放行的话,

才能继续与vsftpd继续会话,否则,直接就被拒绝服务了,不知道对不对?

a,修改/etc/vsftpd.conf

#启用TCP Wrappers

tcp_wrappers=YES

b,修改/etc/hosts.deny

拒绝所有向vsftpd发起连接请求的IP,不过,如果hosts.deny与hosts.allow冲突的话,

以hosts.allow优先处理,这好像就是,先deny所有,然后在hosts.allow开放特权,呵呵

#拒绝所有连入vsftpd的IP先.

vsftpd: ALL

c,修改/etc/hosts.allow

在这里开放允许登录vsftpd的IP地址

关于VSFTPD_LOAD_CONF环境变量,vsftpd的man是这么说的:

"If tcp_wrappers sets the VSFTPD_LOAD_CONF environment variable, then the vsftpd

session will try and load the vsftpd configuration file specified in this variable. "

#限制可以匿名登录vsftpd的IP地址

vsftpd: 192.168.0.,210.83.200.200 : setenv VSFTPD_LOAD_CONF /etc/vsftpd/vsftpd.anonymous

#允许vsftpd的虚拟用户以任何IP连接FTP

vsftpd: ALL : setenv VSFTPD_LOAD_CONF /etc/vsftpd/vsftpd.virtual

d,修改/etc/vsftpd/vsftpd.anonymous

#mkdir /etc/vsftpd/

#nano /etc/vsftpd/vsftpd.anonymous

#允许匿名登录

anonymous_enable=YES

e,修改/etc/vsftpd/vsftpd.virtual

#nano /etc/vsftpd/vsftpd.virtual

#不允许匿名登录

anonymous_enable=NO

5),为不同的用户设置不同的访问权限

a,激活单个用户配置功能,增加以下配置行到vsftpd的配置文件:

#nano /etc/vsftpd.conf

#指定不同用户配置文件的存放路径

user_config_dir=/etc/vsftpd/vsftpd_user_conf

b,普通用户:下载/上传

编辑/etc/vsftpd/vsftpd_user_conf/normal

注意:用户的配置文件名与用户名一致,不过匿名用户的配置文件名为ftp,而不是anonymous

#mkdir /etc/vsftpd/vsftpd_user_conf

#nano /etc/vsftpd/vsftpd_user_conf/normal

加入以下内容:

#允许下载

anon_world_readable_only=NO

#允许写入,上传以及建立目录

write_enable=YES

anon_upload_enable=YES

anon_mkdir_write_enable=YES

c,管理员用户:下载/上传/删除等.

#cp /etc/vsftpd/vsftpd_user_conf/normal /etc/vsftpd/vsftpd_user_conf/admin

编辑admin的配置文件:

#nano /etc/vsftpd/vsftpd_user_conf/admin

管理员除了拥有普通用户的权限以外,还拥有删除/重命名/改变文件属性的权限

加入以下内容:

#允许重命名和删除文件

anon_other_write_enable=YES

#虚拟用户拥有与本地用户相同的权限(由于chmod仅仅对本地用户有效,所以如果想要虚拟用户拥有chmod的权限,这一项必须激活)

virtual_use_local_privs=YES

#允许修改文件属性

chmod_enable=YES

d,网站管理员

#cp /etc/vsftpd/vsftpd_user_conf/admin /etc/vsftpd/vsftpd_user_conf/webmaster

编辑webmaster的配置文件:

#nano /etc/vsftpd/vsftpd_user_conf/webmaster

加入以下内容:

#将FTP家目录指向网站的家目录(我的www目录使用Apache默认的目录)

local_root=/var/www

#默认情况下,上传到FTP站点的文件的拥有者都是ftpguest,其他用户是没有访问权限的

#所以,当访问网站的时候,会出现"没有权限访问该文件的错误",这是由于Apache的用户

#www-data无法访问/var/www下的文件造成的,把umask设置成033甚至000即可解决这个问题.

local_umask=033

e,为normal,admin用户设置对incoming,pub目录不同的权限

阅读了一遍vsftpd man中关于权限的相关设置,似乎没有单独设置每个目录权限的地方?

后来想到是不是可以利用Linux文件系统的文件权限设置来达到此目的,以前在Windows下

利用IIS来架设站点时,我就是利用NTFS权限设置来达到控制不同用户对目录的访问权限.

不过试了一下,还是无法完美的实现以下的权限控制:

incoming pub

normal 读/写 只读

admin 读/写 读/写

举例来说,可以通过把pub设置成只读来控制normal用户只读pub的权限,不过admin对pub也是只读了

不过,还好,因为admin拥有修改目录属性的权限,如果admin用户想要通过FTP来完成管理pub目录的话,可以临时把pub目录修改成读/写属性.

四,小结

1,vsftpd的目标是完成一个简易而且安全性不低的FTPD,功能嘛,似乎还是有点不足,特别是目录权限这方面的设置

如果是对目录权限有比较复杂的需求的话,可以考虑一下Proftpd .

2,在测试的时候,除了使用FTP Client工具以外,最好再使用Sniffer类的软件作为辅助,因为有时候FTP Client并不会完全把

FTPD返回信息呈现在你面前,而有时候,这些信息对排除FTPD故障会有很大帮助的,而一旦使用Sniffer类的软件,所有的

客户端与服务器端交互的信息都不会漏掉的.

五,参考

1,Manpage of VSFTPD.CONF:http://vsftpd.beasts.org/vsftpd_conf.html

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有