免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1330 | 回复: 0
打印 上一主题 下一主题

vsftpd及ftp操作简单介绍 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-12-21 22:42 |只看该作者 |倒序浏览
为了方便在虚拟机上上传一些资料我在debian下安装了一个ftp程序,叫做vsftpd。据说配置比较的简单安全,使用比较方便。因为是临时使用的所以就选择它了。
在deibian命令行下输入
apt-get install vsftpd
安装完后你可以查看一下你的vsftpd服务有没有启动
ps -ef|grep vsftpd
如果输出来的结果显示在运行的话就没有多大问题了
下面是关于vsftpd的一些介绍及配置:都是从网上参考的
vsftpd是standalone方式启动的,它不是通过inetd守护进程启动的(linux和unix网络服务的启动一般有两种方式,standalone和非standalone)。所以你要启动或者停止vsftpd的服务你可以到/etc/init.d/目录下找与vsftpd相关的启动命令,例如要停止vsftpd的服务可以输入
/etc/init.d/vsftpd stop|start|reload|restart

vsftpd相关文件介绍
安装完vsftpd后会安装几个文件
/etc/vsftpd.conf 对vsftpd访问的配置文件
/etc/ftpusers vsftpd不容许登陆的用户的文件
/usr/sbin/vsftpd 启动脚本
/etc/init.d/vsftpd 启动脚本
/etc/pam.d/vsftpd vsftpd认证的配置文件
/var/run/vsftpd vsftpd正在运行的进程

1). 配置vsftpd.conf
listen=YES 独立运行模式
anonymous_enable=NO/YES (允许匿名登陆吗?=YES 可登陆 =NO 不可登陆)
no_anon_password=NO/YES (匿名登陆要密码吗?=YES 要 =NO 不要)
local_enable=YES/NO 本地用户可登陆吗? =YES 要 =NO 不要
write_enable=YES 本地用户有写权限吗?
local_umask=022 权限的掩码
connect_from_port_20=YES 端口设成20 ,不想要,自己在改: connect_from_port_205=YES
idle_session_timeout=600 监听,多常时间,没响应,VSFTPD 把你踢出服务器
data_connection_timeout=600 连接服务器后,数据多常时间不能传入,断开服务
chroot_list_enable=YES 这一行,和下面一行,密切相关
chroot_list_file=/etc/vsftpd.chroot_list 这一行,上一行设置YES才生效。意思是:加入到这个文件内的用户,只能访问自己的目录。其它目录不能访问.建立下面有说明.
secure_chroot_dir=/var/run/vsftpd 意思是:vsftpd 运行的目录。
pam_service_name=vsftpd 加密(pam) 传输模式,这个目录内的: /etc/pam.d/vsftpd
rsa_private_key_file=/etc/ssl/private/ssl-cert-snakeoil.key (KEY文件,不要动)
如果其它的没有。就自己,添加里面。(手动加入的呀。不要懒哦)
use_localtime=YES
connect_timeout=60
accept_timeout=60
max_clients=8
max_per_ip=8
pasv_min_port=0,pasv_max_port=0
local_max_rate=0
tcp_wrappers=YES
nopriv_user=nobody
userlist_enable=YES
userlist_deny=NO
userlist_file=/etc/vsftpd.user_list
还有其它的。好了。就这些了。
3. /etc/vsftpd.user_list 文件的建立
vim /etc/vsftpd.user_list 回车, 把用户加入,为什么加入,上有说明.
按住:shift+! 把: :. ++-- 变成 : 输入: wq 回车 保存了。
想修改,运行: vim /etc/vsftpd.user_list 即可 在不会,就要学一下 vim 命令了。
4. /etc/vsftpd.chroot_list 文件的建立
vim /etc/vsftpd.chroot_list 和上面 vsftpd.user_list 文件建立一样。内用要根据自己的呀.
5.虚拟用户登陆 (建立你要登陆FTP的用户啦)
1)例如:我要建立一个j288com用户
sudo useradd –g 50 –d /home/j288com –s /bin/bash –m j288com 回车
具体:useradd 空各 –g 空各 –d 空各 /home/j288com 空各 –s 空各 /bin/bash 空各 –m 空各 j288com
2)为建立的用户设密码:
sudo passwd 用户名
例如:sudo passwd j288com
Enter new UNIX password: 这里输入密码; 下面会提示再次确认密码
好了。ftp://j288com 登陆服务器
输入你建立的用户名,和密码就可以了.
常见问题:
1).530 Login incorrect.
答: 用户名或密码错误
2).vsftpd.conf 没有我要设置的文件
答:自己建立
3). vsftpd.user_list 文件没有
答:自己建立
4). vsftpd.chroot_list 文件没有
答:自己建立
其它高级设置。自己查看,相关资料。你的FTP服务器现也可以登陆了。

下面就是ftp相关的东西
ftp在传输的时候有两种模式:binary和ascii 这是数据传输中非常重要的问题,因为如果模式使用错误,可能会导致上传的文件不能使用,或者不能被解压,打开。
binary一般是用在上传图片、压缩或打包类的文件
ascii用于传输脚本类的文件用(CGI、HTML),用文件编写的文件。

?
FTP命令大全及其应用  
  ftp的命令行格式为:ftp -v -d -i -n -g[主机名]
     —v 显示远程服务器的所有响应信息。
   -d 使用调试方式。
   -n 限制ftp的自动登录,即不使用.netrc文件。
   -g 取消全局文件名。
  ftp使用的内部命令如下(其中括号表示可选项):   
    1.![cmd[args]]在本地机中执行交互shell、exit回到ftp环境,如!ls*.zip。
  2.¥ macro-ame[args]执行宏定义macro-name。
  3.account[password]提供登录远程系统成功后访问系统资源所需的补充口令。
  4.appendlocal-file[remote-file]将本地文件追加到远程系统主机,若未指定远程系统文件名,则使用本地文件名。
  5.ascii 使用ascii类型传输方式。
  6.bell每个命令执行完毕后计算机响铃一次。
  7.bin使用二进制文件传输方式。
  8.bye退出ftp会话过程。
  9.case在使用mget时,将远程主机文件名中的大写转为小写字母。
  10.cd remote-dir 进入远程主机目录。
  11.cdup进入远程主机目录的父目录。
  12.chmod modefile-name将远程主机文件file-name的存取方式设置为mode,如 chmod 777 a.out。
  13.close中断与远程服务器的ftp会话(与open对应)。
  14.cr使用asscii方式传输文件时,将回车换行转换为回行。
  15.delete remote-file删除远程主机文件。
  16.debug[debug-value]设置调试方式,显示发送至远程主机的每条命令,如debu p 3,若 设为0,表示取消debug。
  17.dir[remote-dir][local-file]显示远程主机目录,并将结果存入local- file。
  18.disconnection同close。
  19.form format将文件传输方式设置为format,缺省为file方式。
  20.getremote-file[local-file]将远程主机的文件remote-file传至本地硬盘 的local-file。
  21.glob设置mdelete、mget、mput的文件名扩展,缺省时不扩展文件名,同命令行的-g参数。
  22.hash每传输1024字节,显示一个hash符号(#)。
  23.help[cmd]显示ftp内部命令cmd的帮助信息,如help get。
  24.idle[seconds]将远程服务器的休眠计时器设为[seconds]秒。
   25.image设置二进制传输方式(同binary)
   26.lcd[dir]将本地工作目录切换至dir。
   27.ls[remote-dir][local-file]显示远程目录remote-dir,并存入本地loca l-file。
   28.macdef macro-name定义一个宏,遇到macdef下的空行时,宏定义结束。
   29.mdelete[remote-file]删除远程主机文件。
   30.mdir remote-files local-file与dir类似,但可指定多个远程文件,如mdi r *.o.*. zipoutfile。
   31.mget remote-files传输多个远程文件。
   32.mkdir dir-name 在远程主机中建一目录。
   33.mls remote-file local-file同nlist,但可指定多个文件名。
   34.mode[mode-name]将文件传输方式设置为mode-name,缺省为stream方式。
   35.modtime file-name显示远程主机文件的最后修改时间。
   36.mput local-file将多个文件传输至远程主机。
   37.newerfile-name如果远程机中file-name的修改时间比本地硬盘同名文件的 时间更近,则重传该文件。
   38.nlist[remote-dir][local-file]显示远程主机目录的文件清单,并存入本 地硬盘的local-file。
   39.nmap[inpatternoutpattern]设置文件名映射机制,使得文件传输时,文件中的 某些字符相互转换,如nmap¥1.¥2.¥3[¥1,¥2].[¥2,¥3],则传输文件a1.a2.a3时 , 文件名变为a1、a2,该命令特别适用于远程主机为非U-NIX机的情况。
   40.ntrans[inchars[outchars]]设置文件名字符的翻译机制,如ntrans1R,则文件 名LL L将变为RRR。
   41.open host[port]建立指定ftp服务器连接,可指定连接端口。
   42.passive进入被动传输方式。
   43.prompt设置多个文件传输时的交互提示。
   44.proxyftp-cmd在次要控制连接中,执行一条ftp命令,该命令允许连接两个ftp 服务器,以在两个服务器间传输文件。第一条ftp命令必须为open,以首先建立两个服务 器间的连接。
   45.put local-file[remote-file]将本地文件local-file传送至远程主机。
   46.pwd显示远程主机的当前工作目录。
   47.quit同bye,退出ftp会话。
   48.quote arg1,arg2……将参数逐字发至远程ftp服务器,如quote syst。
   49.recv remote-file[local-file]同get。
   50.regetremote-file[local-file]类似于get,但若local-file存在,则从上 次传输中断处续传。
   51.rhelp[cmd-name]请求获得远程主机的帮助。
   52.rstatus[file-name]若未指定文件名,则显示远程主机的状态,否则显示文件状态。
   53.rename[from][to]更改远程主机文件名。
   54.reset清除回答队列。
   55.restart marker从指定的标志marker处,重新开始get或put,如restart 130。
   56.rmdir dir-name删除远程主机目录。
   57.runique设置文件名唯一性存储,若文件存在,则在原文件后加后缀。
   58.send local-file[remote-file]同put。
   59.sendport设置PORT命令的使用。
   60.site arg1,arg2……将参数作为SITE命令逐字发送至远程ftp主机。
   61.size file-name显示远程主机文件大小,如site idle 7200。
   62.status显示当前ftp状态。
   63.struct[struct-name]将文件传输结构设置为struct-name,缺省时使用stream结构。
     64.sunique将远程主机文件名存储设置为唯一(与runique对应)。
   65.system显示远程主机的操作系统类型。
   66.tenex将文件传输类型设置为TENEX机所需的类型。
   67.tick设置传输时的字节计数器。
   68.trace设置包跟踪。
   69.type[type-name]设置文件传输类型为type-name,缺省为ascii,如 typebinary,设置 二进制传输方式。
   70.umask[newmask]将远程服务器的缺省umask设置为newmask,如umask 3。
   71.useruser-name[password][account]向远程主机表明自己的身份,需要口令时,必须输入口令,如user anonymous my@email。
   72.verbose同命令行的-v参数,即设置详尽报告方式,ftp服务器的所有响应都将 显示给用户,缺省为on.
   73.?[cmd]同help。 ftp使用的模式一般是这样的:
ftp xxx.xxx.xxx.xxx port
输入帐户密码
binary|ascii 文件传输的模式
PUT   本地端的文件全路径   服务器端的文件全路径.   
GET   服务器端的文件全路径   本地端的文件全路径.
bye参考文章:ubuntu vsftpd 服务器架设


本文来自ChinaUnix博客,如果查看原文请点:http://blog.chinaunix.net/u/25177/showart_1732925.html
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP