linux下purftp服务器的搭建

 

简介:

pureftp支持了安全的mysql虚拟账号验证,这样保证了系统账户的安全,与pureftpd-admin配合起来管理起来也更方便,符合人们的使用习惯

PureFTPd是一款专注于程序健壮和软件安全的免费FTP服务器软件(基于BSD License)。其可以在多种类Unix操作系统中编译运行,包括Linux、OpenBSD、NetBSD、FreeBSD、DragonFly BSD、Solaris、Tru64、Darwin、Irix and HP-UX。PureFTPd还有Android移植版本。

     PureFTPd由Troll-FTPd发展而来,Troll-FTPd是Arnt Gulbrandsen于1995年到1999年在Trolltech工作时所作。Gulbrandsen停止维护Troll-FTPd项目后,Frank Denis于2001年开始维护并将其改名为PureFTPd,目前的开发维护者是由Denis领导的团队。

 

原理图:

wps_clip_image-5675[5]

所需软件包及附件:

wps_clip_image-14006[4]

wps_clip_image-26367[4]

环境搭建:

1、配置网络地址:

# vim /etc/sysconfig/network-scripts/ifcfg-eth0

wps_clip_image-11159[4]

2、重启网络服务:

# service network restart

3、挂载光盘:

# mkdir /mnt/cdrom    //建立挂载点

# mount /dev/cdrom /mnt/cdrom/

4、安装pure-ftp所需的软件包:

# yum install httpd mysql mysql-server mysql-devel php php-mysql

5、启动httpd服务:

# service httpd start

6、启动mysql服务:

# service mysqld start

# mysqladmin -u root -p password "123"

四、源码安装pure-ftpd服务:

1、拆解pure-ftpd源码:

# tar -zxvf pure-ftpd-1.0.36.tar.gz -C /usr/local/src/

# cd /usr/local/src/pure-ftpd-1.0.36/

2、配置pure-ftp源码:

# ./configure \

--prefix=/usr/local/pureftpd \

--with-mysql \

--with-shadow \

--with-pam  \

--with-welcomemsg \

--with-uploadscript \

--with-cookie \

--with-virtualchroot \

--with-virtualhosts \

--with-diraliases \

--with-quotas \

--with-puredb \

--with-sysquotas \

--with-ratios \

--with-ftpwho \

--with-throttling \

--with-language=simplified-chinese

3、编译pure-ftp源码:

# make

4、安装pure-ftp源码:

# make install

5、手动生成pure-ftpd的服务脚本:

# cd /usr/local/src/pure-ftpd-1.0.36/configuration-file/

# chmod a+x pure-config.pl

# cp pure-config.pl  /usr/local/pureftpd/sbin/

# mkdir /usr/local/pureftpd/etc

# cp pure-ftpd.conf /usr/local/pureftpd/etc/

6、生成pure-ftpd服务的控制脚本:

# cd /usr/local/src/pure-ftpd-1.0.36/

# cp contrib/redhat.init /etc/init.d/pureftpd

7、编辑控制文件:

# vim /etc/init.d/pureftpd
wps_clip_image-31714[4]

wps_clip_image-5502[4]

wps_clip_image-15142[4]

8、将pureftpd服务设置成开机自动启动:

# chmod 755 /etc/init.d/pureftpd

# chkconfig --add pureftpd

# chkconfig pureftpd on

 

配置pure-ftpd的用户登录环境

1、编辑配置文件

# vim /usr/local/pureftpd/etc/pure-ftpd.conf

不允许匿名登录:

wps_clip_image-31974[4]

用户第一次登录后自动创建家目录:

wps_clip_image-16619[4]

2、配置虚拟用户登录环境

# mkdir /ftproot    /虚拟帐号的根目录,相当于一个用户的组目录

# chmod -R 777 /ftproot  <这步不做可以能会引起登录时报421错误>

# useradd virtualftp -d /ftproot -s /sbin/nologin -M  //创建虚拟用户映射的系统用户

# chown virtualftp:virtualftp /ftproot

3、将pure-ftpd服务添加到环境变量

# echo PATH=$PATH:/usr/local/pureftpd/bin/ >>/etc/profile

# . /etc/profile

 

设置pure-ftpd用户的mysql认证

1、配置pure-ftpd主配置文档:

#vim /usr/local/pureftpd/etc/pure-ftpd.conf

wps_clip_image-13505[4]

2、产生并配置数据库配置文件pureftpd-mysql.conf

拷贝pureftpd-mysql.conf文件到指定目录:

# cp pureftpd-mysql.conf /usr/local/pureftpd/etc/

3、编辑pureftpd-mysql.conf的配置:

# vim /usr/local/pureftpd/etc/pureftpd-mysql.conf

wps_clip_image-18043[4]

wps_clip_image-712[4]

 

创建pure-ftpd的数据库文件:

1、编辑pureftp.sql:

# vim pureftp.sql

wps_clip_image-3556[4]

wps_clip_image-12093[4]

2、导入数据库文件pureftp.sql:

# mysql -u root -p < pureftp.sql

3、添加连接mysql用户:

# mysql -u root -p

mysql>grant all privileges on ftpusers.* to ftp@localhost identified by 'tmppasswd';

mysql>flush privileges;

 

创建并配置pure-ftpd管理程序pureadmin:

1、将pureadmin包拆解到httpd主目录下:

# tar -zxvf PureAdmin-0.3.tar.gz -C /var/www/html/

# mv /var/www/html/PureAdmin-0.3 /var/www/html/pureadmin

2、修改pureadmin的配置文件

# cd /var/www/html/pureadmin

3、编辑pureadmin的配置页面:

# vim config.php

wps_clip_image-15129[4]

wps_clip_image-24572[4]

$cfg['dir']='/ftproot/'; //默认家目录;

4、启动pure-ftpd服务:

# service pureftpd start

5、重启httpd服务:

# service httpd restart

 

验证测试:

现在可以登录使用了

http://192.168.10.100/pureadmin

登录:用户:admin ; 密码:123;验证码不用

wps_clip_image-3934[4]

wps_clip_image-199[4]

创建ftp新用户:

wps_clip_image-24780[4]

创建成功:

wps_clip_image-19246[4]

使用user1帐号登录ftp:

wps_clip_image-14121[4]

wps_clip_image-21125[4]

目录已经创建:

wps_clip_image-118[4]

测试成功!!

你可能感兴趣的:(android,linux,安全,账号,的)