Mysql实例PureFTP借助MySQL实现用户身份验证的 *** 作教程

Mysql实例PureFTP借助MySQL实现用户身份验证的 *** 作教程,第1张

概述介绍《Mysql实例PureFTP借助MySQL实现用户身份验证的 *** 作教程》开发教程,希望对您有用。

《MysqL实例PureFTP借助MysqL实现用户身份验证的 *** 作教程》要点:
本文介绍了MysqL实例PureFTP借助MysqL实现用户身份验证的 *** 作教程,希望对您有用。如果有疑问,可以联系我们。

MysqL必读pureftp集成MysqL身份验证是将ftp用户信息保存到MysqL数据库中,这样可以对大量的ftp服务器做集中管理,对用户帐号的维护只要通过MysqL的 *** 作就可以完成.

MysqL必读一、下载pureftp源代码,并确定MysqL已经安装好

MysqL必读tar zxvf pure-ftpd-1.0.20.tar.gz cd pure-ftpd-1.0.20./configure --prefix=/usr/local/pureftpd \--with-cookie \--with-throttling \--with-ratios \--with-quotas \--with-sysquotas \--with-uploadscript \--with-virtualhosts \--with-virtualchroot \--with-virtualchroot \--with-diraliases \--with-peruserlimits \--with-language=simplifIEd-chinese \--with-MysqL=/usr/local/MysqL \--with-paranoIDmsg \--with-altlogmakemake checkmake installmkdir -m 777 /usr/local/pureftpd/etccp pureftpd-MysqL.conf  /usr/local/pureftpd/etc/pureftpd-MysqL.confcp configuration-file /pure-ftpd.conf /usr/local/pureftpd/etc/pure-ftpd.confcp configuration-file/pure-config.pl  /usr/local/pureftpd/bin/pure-config.pl

MysqL必读注意    Cprefix=/usr/local/pureftpd 参数指定了pureftpd的安装路径 Cwith-MysqL=/usr/local/MysqL 参数指定了MysqL的安装路径 Cwith-language=simplifIEd-chinese 参数指定了服务器返回信息使用的语言

MysqL必读添加pureftpd为系统服务

MysqL必读# cp contrib/redhat.init /etc/init.d/pureftpd# vi /etc/init.d/pureftpd

MysqL必读修改18/19行

MysqL必读fullpath=/usr/local/sbin/$progpureftpwho=/usr/local/sbin/pure-ftpwho

MysqL必读为:

MysqL必读fullpath=/usr/local/pureftpd/sbin/$progpureftpwho=/usr/local/pureftpd/sbin/pure-ftpwho

MysqL必读修改24行

MysqL必读$fullpath /etc/pure-ftpd.conf --daemonize

MysqL必读为 

MysqL必读$fullpath /usr/local/pureftpd/etc/pure-ftpd.conf --daemonize# chmod 755 /etc/init.d/pureftpd# chkconfig --add pureftpd# chkconfig pureftpd on

MysqL必读修改配置文件

MysqL必读# vi /usr/local/pureftpd/etc/pure-ftpd.conf

MysqL必读其中可以修改最大连接数、空闲时间等,详细介绍见http://everspring.blog.51cto.com/497193/104618
其中有几项要修改:

chrootEveryone              yes  限定在自己的家目录 NoAnonymous                yes  不允许匿名登录 Bind                      127.0.0.1,21        监听本机回环 <可选> Bind                      192.168.0.254,21    监听本机IP  <自行添加的,非必须> CreateHomeDir              yes  允许用户登录后自动创建家目录  <必须>  

MysqL必读如果启用了iptables,还必须修改下面这一行:
PassivePortRange          30000 50000保存退出.

MysqL必读iptables开启相关端口:

MysqL必读iptables -I input -p tcp --dport 21 -j ACCEPTiptables -I input -p tcp --dport 30000:50000 -j ACCEPT
MysqL必读/etc/rc.d/init.d/iptables save

MysqL必读二、建立MysqL认证数据库表
在MysqL服务器中建立pureftpd数据库

MysqL必读MysqL>CREATE DATABASE pureftpd;MysqL>grant all on pureftpd.* to pureftpd@"localhost" IDentifIEd by 'pureftpd';MysqL>use pureftpd;MysqL>CREATE table `users` ( `ID` int(32) unsigned NOT NulL auto_increment,`User` varchar(16) NOT NulL default '',`Password` varchar(64) NOT NulL default '',`UID` varchar(11) NOT NulL default '-1',`GID` varchar(11) NOT NulL default '-1',`Dir` varchar(128) NOT NulL default '',`QuotaSize` smallint(5) NOT NulL default '0',`Quotafiles` int(11) NOT NulL default '0',`ulBanDWIDth` smallint(5) NOT NulL default '0',`DLBanDWIDth` smallint(5) NOT NulL default '0',`ulRatio` smallint(6) NOT NulL default '0',`DLRatio` smallint(6) NOT NulL default '0',`comment` tinytext NOT NulL,`ipaccess` varchar(15) NOT NulL default '*',`status` enum('0','1') NOT NulL default '0',`create_date` datetime NOT NulL default '0000-00-00 00:00:00',`modify_date` datetime NOT NulL default '0000-00-00 00:00:00',PRIMARY KEY (`ID`,`User`),UNIQUE KEY `User` (`User`) )TYPE=MyISAM auto_INCREMENT=5 ;

MysqL必读三、建立用于pureftpd认证用户的系统信息
建立用于pureftpd认证用户和ftp服务器根目录

MysqL必读创建专门用于上传文件的用户

MysqL必读groupadd download -g 2000 useradd download -u 2000 -g download -s /sbin/nologin

MysqL必读创建专门用于下载的用户

MysqL必读groupadd upload -g 2001 useradd upload -u 2001 -g download -s /sbin/nologinmkdir /ftproot chown -R upload /ftproot      //让upload用户作为ftp根目录的属主 chgrp -R download /ftproot   //让download用户为ftp根目录的属组 chmod 750 /ftproot           //让upload用户拥用所有权限,让download用户只有读权限

MysqL必读四、修改pureftpd的配置文件
修改pureftp主配置文件

MysqL必读vi /usr/local/pureftpd/etc/pure-ftpd.conf
MysqL必读ChrootEveryone         yesbrokenClIEntsCompatibility   noMaxClIEntsNumber        50Daemonize           yesMaxClIEntsPerIP        8VerboseLog           yesdisplayDotfiles        yesAnonymousOnly         noNoAnonymous          noSyslogFacility        DontResolve          yesMaxIDleTime          15 #  在使用ls命令时显示的最多的文件个数,该选项有两个参数第一个是文件数,第二个是目录深度limitRecursion        10000 8AnonymousCanCreateDirs    noMaxLoad            4PassivePortRange       30000 50000 使用被动模式,被动端口的范围是30000到50000AntiWarez           yesUserBanDWIDth         1000Umask             133:022MinUID            100AllowUserFXP         noAllowAnonymousFXP       noProhibitDotfilesWrite     noProhibitDotfilesRead     noautoRename          noAnonymousCantUpload      yes 禁止匿名用户上传CreateHomeDir         no 禁止登录用户自动创建家目录PIDfile            /var/run/pure-ftpd.pIDMaxdiskUsage         99CustomerProof         yes

MysqL必读修改pureftp MysqL认证文件

MysqL必读vi /usr/local/pureftpd/etc/pureftpd-MysqL.conf
MysqL必读MysqLServer 127.0.0.1MysqLPort 3306MysqLUser pureftpdMysqLPassword pureftpdMysqLDatabase pureftpdMysqLCrypt cleartext 暗码在数据表中的存储方式,这里选择明文用cleartext、加密使用cryptMysqLGetPW SELECT Password FROM users WHERE User='\L'MysqLGetUID SELECT UID FROM users WHERE User='\L'MysqLGetGID SELECT GID FROM users WHERE User='\L'MysqLGetDir SELECT Dir FROM users WHERE User='\L'MysqLGetBanDWIDthul SELECT ulBanDWIDth FROM users WHERE User='\L'MysqLGetBanDWIDthDL SELECT DLBanDWIDth FROM users WHERE User='\L'

MysqL必读五、运行pureftpd
添加upload用户,用户名可以任意,但是要对应系统用户的的uID和gID,以获取文件系统的的相关权限

MysqL必读INSERT INTO `users` VALUES (1,'download','2000','/ftproot','','*','1','2013-06-24 16:10:00','2013-06-24 16:10:00');

MysqL必读添加download用户

MysqL必读INSERT INTO `users` VALUES (2,'upload','2001','2013-06-24 16:10:00');

MysqL必读运行pureftpd服务器

MysqL必读/usr/local/pureftpd/bin/pure-config.pl /usr/local/pureftpd/etc/pure-ftpd.conf

MysqL必读现在在客户端使用浏览器打开http://服务器IP:21 使用用户upload和download测试登录

MysqL必读六、用facl实现相同目录不同用户使用不同访问权限

MysqL必读chown -R upload:upload /ftprootchomod 700  /ftprootsetfacl -R d:u:download:rx /ftproot 

MysqL必读后以后创建的子目录和子文件继承facl

MysqL必读setfacl -R u:download:rx  /frptoot  

MysqL必读 让当前目录的facl生效

MysqL必读Pureftp表字段说明

MysqL必读CREATE table IF NOT EXISTS `ftpd` (`User` varchar(16) NOT NulL DEFAulT ” COMMENT ‘用户名',`status` enum(‘0′,'1′) NOT NulL DEFAulT ‘0' COMMENT ‘可用状态:0 C 不可用;1 C 正在使用',`Password` varchar(64) NOT NulL DEFAulT ” COMMENT ‘暗码',`UID` varchar(11) NOT NulL DEFAulT ‘-1′ COMMENT ‘用户ID',`GID` varchar(11) NOT NulL DEFAulT ‘-1′ COMMENT ‘组ID',`Dir` varchar(128) NOT NulL DEFAulT ” COMMENT ‘拥有的权限路径',`ulBanDWIDth` smallint(5) NOT NulL DEFAulT ‘0' COMMENT ‘上传带宽',`DLBanDWIDth` smallint(5) NOT NulL DEFAulT ‘0' COMMENT ‘下载带宽',`comment` tinytext NOT NulL COMMENT ‘备注',`ipaccess` varchar(15) NOT NulL DEFAulT ‘*' COMMENT ‘IP地址',`QuotaSize` smallint(5) NOT NulL DEFAulT ‘0' COMMENT ‘大小配额',`Quotafiles` int(11) NOT NulL DEFAulT ‘0' COMMENT ‘文件类型配额',PRIMARY KEY (`User`)) ENGINE=MyISAM DEFAulT CHARSET=gbk COMMENT='ftp用户名暗码表';

内存溢出PHP培训学院每天发布《MysqL实例PureFTP借助MysqL实现用户身份验证的 *** 作教程》等实战技能,PHP、MysqL、liNUX、APP、Js,CSS全面培养人才。

总结

以上是内存溢出为你收集整理的Mysql实例PureFTP借助MySQL实现用户身份验证的 *** 作教程全部内容,希望文章能够帮你解决Mysql实例PureFTP借助MySQL实现用户身份验证的 *** 作教程所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://www.outofmemory.cn/sjk/1156395.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-01
下一篇 2022-06-01

发表评论

登录后才能评论

评论列表(0条)

保存