- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
基于访问控制和虚拟用户FTP服务器实现
基于访问控制和虚拟用户FTP服务器实现
摘要:该文讨论了FTP服务器的典型访问方式,通过配置文件的编辑实现了FTP的访问控制,通过构建的数据库实现了FTP的基于虚拟用户的访问,通过该文的所述的方法对实现FTP服务器安全及正常的运行会有很大的帮助。
关键词:LINUX;FTP;访问控制;身份验证;虚拟用户
中图分类号:TP393 文献标识码:A 文章编号:1009-3044(2013)36-8265-02
随着互联网使用越来越普及,网民会经常需要在网络中通过网页或者命令行方式进行上传或者下载的任务,这些任务的使用是基于FTP( File Transfer Protocol,文件传输协议)在互联网络的实现,该协议在FTP服务器(存放文件资源)和FTP客户端通过2对端口进行通讯。在服务器端依靠TCP端口20和21进行工作,使用端口20进行数据的接收和发送,而使用端口21进行TCP传输控制,而客户端可以随机选择大于1024的端口和FTP服务器的20个21端口进行连接。
在目前的互联网络中,由于上传下载的业务量相当大,对应的FTP服务器会承担越来越重的工作任务,要确保这些服务器的安全及正常使用,可以使用身份验证和访问控制来实现。下面就这两个方面来阐述:(本文所述为基于RED HAT ENTERPRISE LINUX 5的配置)
1 FTP访问控制
可以修改和FTP配置文件所在路径下的文件ftpusers和user_list达到对不同的用户访问控制的目的。可以在ftpusers文件中添加用户,那么该用户就不被允许登陆FTP服务器。而是否可以使用user_list文件中的用户登陆FTP服务器与在主配置文件/etc/vsftpd/vsftpd.conf中的定义有关,如果定义了userlist_deny=NO,则仅仅允许在该文件中中出现的用户登陆FTP服务器,而如果定义userlist_deny=YES,那么该文件中出现的用户不被允许登陆FTP服务器。
2 身份验证
对FTP服务器的访问可以采用三种方式:
1)匿名访问
这种访问模式不需要用户输入身份信息,系统会自动采用anonymous用户连接FTP服务器,而且不需要密码,使用比较简单也很普遍,但是由于访问量较大,对服务器有较高要求。
2)采用LINUX服务器的本地用户在远程登录
采用这种方式需要有本地账号,如果访问的人数太多,而且人员在企业流动性很大,分配给用户的目录较多导致管理上比较困难。
3)采用虚拟用户访问
管理员可以在服务器端创建虚拟用户,让远程用户使用虚拟用户来登录服务器,可以避免上边出现的两个问题,由于需要知道虚拟用户的账号和口令,所以不会使得对所有无关用户都可以访问,访问被局限于一个范围,同时由于虚拟用户对应的目录就一个,管理上更加简单,如果需要不同的权限可以设置不同的虚拟用户来解决,这样做也不会创建大量的目录,管理上不会那么困难。下面是虚拟用户的配置和测试步骤:
① 要安装db4-utils-4.3.29-9.fc6.i386.rpm这个软件包(笔者是在RHEL5版本上使用),使用这个软件可以安装一个创建口令库文件的命令db_load。
② 建待验证的用户和口令文件,在该文件中,单数行为用户名,双数行为口令。
#vi /etc/vsftpd/vsftpd_log.txt
添加如下用户及口令
图1
③ 用如下命令创建对应于vsftpd_log.txt的数据库文件
#db_load -T -t hash -f /etc/vsftpd/vsftpd_login.txt /etc/vsftpd/vsftpd_login.db
④ 辑虚拟用户验证的认证文件(该认证文件会被VSFTPD配置文件调用),该文件位于/etc/ vsftpd/vsftpd,可以将原件所有内容注释掉(加上“#”),同时添加如下两行,参数DB中的文件名和第三步的数据库文件同名,然后保存即可。
auth required /lib/security/pam_userdb.so db=/etc/vsftpd/vsftpd_login
account required /lib/security/pam_userdb.so db=/etc/vsftpd/vsftpd_login
⑤ 立虚拟账号并配置相应的用户目录(可以任意选位置),并根据需要设定权限,命令如下:
# useradd -s /sbin/nologin -d /var/ftp/zs (设定zs这个虚拟用户对应的主目录,为安全起见,所以加上-s /sbin/nologin使得客户端登录FTP
文档评论(0)