linux下vsftpd的安装及配置使用详细步骤(推荐)

vsftpd 是“very secure FTP daemon”的缩写,安全性是它的一个最大的特色。java

vsftpd 是一个 UNIX 类操做系统上运行的服务器的名字,它能够运行在诸如 Linux、BSD、Solaris、 HP-UNIX等系统上面,是一个彻底免费的、开放源代码的ftp服务器软件,支持不少其余的 FTP 服务器所不支持的特征。linux

好比:很是高的安全性需求、带宽限制、良好的可伸缩性、可建立虚拟用户、支持IPv六、速率高等。apache

vsftpd是一款在Linux发行版中最受推崇的FTP服务器程序。特色是小巧轻快,安全易用。centos

1.1  安装安全

命令:bash

?
1
yum install vsftpd -y

配置Vsftpd服务器

安装完以后咱们要对它进行配置,才能正常使用。dom

编辑vsftpd的配置文件ssh

?
1
vi /etc/vsftpd/vsftpd .conf

在配置文件中找到“anonymous_enable=YES”,将"YES"改成"No",将匿名登陆禁用。ui

添加开机自动启动,

?
1
chkconfig vsftpd on

不肯定是否已经加入了开机启动项能够运行chkconfig –list进行查看

1.2  建立用户

命令:useradd ftpuser

指定密码:passwd ftpuser

此用户就是用来登陆ftp服务器用的。

这样一个用户建完,能够用这个登陆,记得用普通登陆不要用匿名了。登陆后默认的路径为 /home/ftpuser.

----------------------------------------------------------------------------------------------------------------------------------

设置FTP用户的帐号,例如帐号为“ftpuser1”,目录为/home/ftpuser1,且设置不容许经过ssh登陆。

?
1
useradd -d /home/ftpuser -s /sbin/nologin ftpuser

设置帐号对应的密码,例如密码为“ftpuser”

?
1
passwd ftpuser

1.3  开启selinux权限

VSFTPD是一个FTP服务器程序,而后SELinux是CentOS的防火墙组件。因为 vsftpd 默认被 SELinux 拦截,因此会遇到的FTP如下的问题:

1.226 Transfer done (but failed to open directory).(传输完成,可是打开路径失败)

2.550 Failed to change directory(更改路径失败)

3.
553 Could not create file.

4.

或者干脆在发送了LIST命令之后,服务器没响应,超时断开。

遇到这样的问题,一般是vsftpd 没有足够的权限,颇有多是被SELinux阻止了。

查看命令:getsebool -a | grep ftp

?
1
2
3
4
5
6
7
8
9
getsebool -a | grep ftpd
#如下是显示出来的权限,off是关闭权限,on是打开权限
allow_ftpd_anon_write --> off
allow_ftpd_full_access --> off
allow_ftpd_use_cifs --> off
allow_ftpd_use_nfs --> off
ftpd_connect_db --> off
ftpd_use_passive_mode --> off
ftp_home_dir --> off

其中,ftp_home_dir和allow_ftpd_full_access必须为on 才能使vsftpd 具备访问ftp根目录,以及文件传输等权限。

      设置命令:setsebool -p xxxxxx on

?
1
2
[root@bogon ~] # setsebool -P allow_ftpd_full_access on
[root@bogon ~] # setsebool -P ftp_home_dir on

1.4  设置或关闭防火墙

由于ftp默认的端口为21,而centos默认是没有开启的,因此要修改iptables文件

设置:vi /etc/sysconfig/iptables

在行上面有22 -j ACCEPT 下面另起一行输入跟那行差很少的,只是把22换成21,而后:wq保存。

还要运行下,重启iptables

重启:service iptables restart

关闭防火墙:service iptables stop

禁用防火墙重启:chkconfig iptables off

1.5  启动vsftpd

命令:service vsftpd start

  java客户端(代码)调用

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
package com.jonychen.util;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.io.InputStream;
import java.net.SocketException;
import java.util.Date;
import java.util.UUID;
import org.apache.commons.net. ftp .FTP;
import org.apache.commons.net. ftp .FTPClient;
public class FtpUploadUtil {
   private static ThreadLocal<FTPClient> threadLocal = new ThreadLocal<>();
   private static ThreadLocal<String> threadLocalHost = new ThreadLocal<>();
   public static void init(String host,int port,String username,String password) throws SocketException, IOException {
     FTPClient client = threadLocal.get();
     if (client==null) {
       client = new FTPClient();
       //1 .链接
       client.connect(host,port);
       //2 .登陆
       client.login(username,password);
       threadLocal. set (client);
       threadLocalHost. set (host);
     }
   }
   public static String upload(InputStream local ,String fileName,String path) throws SocketException, IOException {
     String datePath = DateUtil.date2Str(new Date(), "/yyyy/MM/dd/" );
     // 路径添加日期
     path+=datePath;
     FTPClient client = threadLocal.get();
     String host = threadLocalHost.get();
     //3 .指定文件上传路径(路径不存在返回 false )
     boolean exists = client.changeWorkingDirectory(path);
     if (!exists) {
       String pathArray[] = path. split ( "/" );
       String temp = "/" ;
       for (String p:pathArray) {
         temp+=(p+ "/" );
         //4 .若是文件路径不存在,则建立(一次只能建立一级目录)
         client.makeDirectory(temp);
       }
       // 从新指定文件上传路径
       client.changeWorkingDirectory(path);
     }
     //5 .指定文件类型
     client.setFileType(FTP.BINARY_FILE_TYPE);
     // 获取后缀
     String suffix = fileName.substring(fileName.lastIndexOf( "." ));
     String uuid = UUID.randomUUID().toString();
     //6 .执行上传
     client.storeFile(uuid+suffix, local );
     //7 .退出
     client. logout ();
     //8 .断开链接
     client.disconnect();
     threadLocalHost.remove();
     threadLocal.remove();
     return "http://" +host+ "/jonychen" +datePath+uuid+suffix;
   }
   public static void main(String[] args) throws SocketException, IOException {
     InputStream local = new FileInputStream( "D:\\Documents\\Pictures\\01.png" );
     init( "192.168.178.161" , 21, "ftpuser" , "111111" );
      // 上传路径
     String res = upload( local , "code.png" , "/home/ftpuser/ego" );
     System.out.println(res);
   }
}

总结

以上所述是小编给你们介绍的linux下vsftpd的安装及配置使用详细步骤

相关文章
相关标签/搜索