ubuntu搭建sftp服务

柔情只为你懂 2023-10-16 09:36 177阅读 0赞

安装OpenSSH服务器

Ubuntu通常已经预装了OpenSSH客户端,但如果您还没有OpenSSH服务器,请在终端中执行以下命令来安装:

  1. sudo apt update
  2. sudo apt install openssh-server

f2473c867b874840a51068062b55b8c9.png

创建SFTP用户和组

创建一个新的用户组(例如 sftp_users),用于管理SFTP用户:

  1. sudo groupadd sftp_users

df07829410964f8ab08e61670424ce56.png
创建一个新的SFTP用户(例如 sftpuser),并将其添加到新创建的组。同时设置该用户的密码:

  1. sudo useradd -m sftpuser -g sftp_users
  2. sudo passwd sftpuser

设置SFTP目录和权限" class="reference-link">3fe48b867c1f4f269b56d91a5a260821.png 设置SFTP目录和权限

修改sftp_users用户组用户目录权限

因为使用了ChrootDirectory /data/sftp 作为sftp_users的sftp根目录,现在来修改权限

为sftp选择/新建一个工作目录,目录的所有上级目录属主必须为root,且不能为777的权限

  • 创建一个新目录,用作SFTP用户的根目录(例如 /mysftp):

    sudo mkdir /root/mysftp

bc60d0b294784f5eb5a1abe92d1242ed.png

  • 为新创建的SFTP用户创建一个子目录,作为其个人目录:

    sudo mkdir /root/mysftp/one

6aa083a6c60c49fcbe4537c838d08bd0.png

  • 更改SFTP根目录和个人目录的所有者和权限:

例子:将档案 file1.txt 的拥有者设为 users,群体的使用者 jessie :








1

chown users:jessie file1.txt

例子:将目录下的所有档案与子目录的拥有者皆设为 users 群体的使用者 lamport :








1

chown -R lamport:users *

ChrootDirectory设置的目录权限及其所有的上级文件夹权限,属主和属组必须是root;

ChrootDirectory设置的目录权限及其所有的上级文件夹权限,只有属主能拥有写权限,也就是说权限最大设置只能是755

  1. sudo chown root:root /root/mysftp
  2. sudo chmod 755 /root/mysftp

81a0651c34e343e0a3f47aec9b071781.png

  1. chown sftpuser:sftp_users /root/mysftp/one/
  2. chmod 700 /root/mysftp/one

配置OpenSSH以限制SFTP用户的访问

编辑 /etc/ssh/sshd_config 文件以限制SFTP用户对其根目录的访问:

sudo nano /etc/ssh/sshd_config

在文件末尾添加以下内容:

  1. Match Group sftp_users #新建的用户组
  2. ChrootDirectory /root/mysftp #新建的sftp根目录
  3. ForceCommand internal-sftp #指定sftp命令,不能ssh连接
  4. AllowTcpForwarding no #禁止tcp转发
  5. X11Forwarding no #禁止X11转发

保存文件并退出编辑器。

重新启动OpenSSH服务器

  1. sudo systemctl restart sshd

测试连接

使用sftp连接工具

cf99742fe0b4481792217250cacc59e2.png

8b6839b74e574a58bbac4ed87585df70.png

86f95cb48de24b1b94fbf3d8c8f79383.png

发表评论

表情:
评论列表 (有 0 条评论,177人围观)

还没有评论,来说两句吧...

相关阅读

    相关 UbuntuSFtp

    需求:在服务器上开通SFTP文件服务,允许某些用户上传及下载文件。但是这些用户只能使用SFTP传输文件,不能使用SSH终端访问服务器,并且SFTP不能访问系统文件(即所谓的“J