首页 / MYSQL / vsftpd+pam+mysql
vsftpd+pam+mysql
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了vsftpd+pam+mysql,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含3523字,纯文字阅读大概需要6分钟。
内容图文
![vsftpd+pam+mysql](/upload/InfoBanner/zyjiaocheng/477/2f7d7c023e0c40fda76d40004b34cfb8.jpg)
mysql> use vsftpd;
mysql> create table users (
-> id int AUTO_INCREMENT NOT NULL,
-> name char(20) binary NOT NULL,
-> password char(48) binary NOT NULL,
-> primary key(id)
-> );
2、添加测试的虚拟用户
mysql> insert into users(name,password) values(‘tom‘,passwd(‘xsl’);
mysql> insert into users(name,password) values(‘boy‘, passwd(‘xsl’);
三、配置vsftpd
1.建立pam认证所需文件
#vi /etc/pam.d/vsftpd.mysql
添加如下两行
auth required /lib/security/pam_mysql.so user=vsftpd passwd=vsftpd host=localhostdb=vsftpd table=users usercolumn=name passwdcolumn=password crypt=2
account required /lib/security/pam_mysql.so user=vsftpdpasswd=vsftpd host=localhost db=vsftpd table=users usercolumn=namepasswdcolumn=password crypt=2
2.修改vsftpd的配置文件,使其适应mysql认证
建立虚拟用户映射的系统用户及对应的目录
#useradd -s /sbin/nologin vuser
#chmod go+rx /home/vuser
请确保/etc/vsftpd.conf中已经启用了以下选项
anonymous_enable=YES
local_enable=YES
write_enable=YES
anon_upload_enable=NO
anon_mkdir_write_enable=NO
chroot_local_user=YES
而后添加以下选项
guest_enable=YES
guest_username=vuser
并确保pam_service_name选项的值如下所示
pam_service_name=vsftpd.mysql
#这个文件名称一定要与上面所建立的pam文件名称相同
四、启动vsftpd服务
# service vsftpd start
# chkconfig vsftpd on
使用虚拟用户登录,验正配置结果,以下为本机的命令方式测试,你也可以在其它Win Box上用IE或者FTP客户端工具登录验正
# ftp localhost
如果使用命令方式登录时,如果出现
[root@localhost ~]# ftp localhost
Connected to localhost
220 (vsFTPd 2.0.5)
530 Please login with USER and PASS.
530 Please login with USER and PASS.
KERBEROS_V4 rejected as an authentication type
Name (192.168.0.104:root): tom
331 Please specify the password.
Password:
530 Login incorrect.
Login failed.
ftp>
这样你的字样的话,请查看日志信息,使用tail /var/log/secure命令
Oct 19 15:41:42 localhost vsftpd: pam_mysql - MySQL error(Can‘t connect to local MySQL server through socket ‘/var/lib/mysql/mysql.sock‘(2))
Oct 19 15:43:02 localhost vsftpd: pam_mysql - MySQL error (Can‘t connect tolocal MySQL server through socket ‘/var/lib/mysql/mysql.sock‘ (2))
如果出现这样的字样,说明pam-mysql模块无法通过mysql的套接字域mysql建立连接。
解决办法:
将认证模块中的host=localhost,改为host=127.0.0.1
[root@bogon pub]# ftp 127.0.0.1
Connected to 127.0.0.1 (127.0.0.1).
220 (vsFTPd 2.2.2)
Name (127.0.0.1:root): tom
331 Please specify the password.
Password:
500 OOPS: cannot change directory:/home/vuser
解决办法:将selinux 设置为关闭,重启服务器即可。
五、配置虚拟用户具有不同的访问权限
vsftpd可以在配置文件目录中为每个用户提供单独的配置文件以定义其ftp服务访问权限,每个虚拟用户的配置文件名同虚拟用户的用户名。配置文件目录可以是任意未使用目录,只需要在vsftpd.conf指定其路径及名称即可。
1、配置vsftpd为虚拟用户使用配置文件目录
# vim vsftpd.conf
添加如下选项
user_config_dir=/etc/vsftpd/vusers
2、创建所需要目录,并为虚拟用户提供配置文件
# mkdir /etc/vsftpd/vusers/
# cd /etc/vsftpd/vusers/
# touch tom boy
3、配置虚拟用户的访问权限
虚拟用户对vsftpd服务的访问权限是通过匿名用户的相关指令进行的。比如,如果需要让tom用户具有上传文件的权限,可以修改/etc/vsftpd/vusers/tom文件,在里面添加如下选项即可。
#上传权限
anon_upload_enable=YES
#创建文件权限
anon_mkdir_write_enable=YES
#删除文件权限
anon_other_write_enable=YES
这样就可以指定虚拟用户的访问权限了
vsftpd+pam+mysql
标签:security 数据库 mysql 程序 开发
本文系统来源:http://fuqiuzeng.blog.51cto.com/11547721/1908845
内容总结
以上是互联网集市为您收集整理的vsftpd+pam+mysql全部内容,希望文章能够帮你解决vsftpd+pam+mysql所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。