`

在 Linux 中为非 SSH 用户配置 SFTP 环境

阅读更多
在某些环境中,系统管理员想要允许极少数用户在可以传输文件到Linux机器中,但是不允许使用 SSH。要实现这一目的,我们可以使用SFTP,并为其构建chroot环境。

SFTP & chroot背景:




SFTP是指SSH文件传输协议(SSH File Transfer protocol)或安全文件传输协议(Secure File Transfer Protocol),它提供了可信数据流下的文件访问、文件传输以及文件管理功能。当我们为SFTP配置chroot环境后,只有被许可的用户可以访问,并被限制到他们的家目录中,换言之:被许可的用户将处于牢笼环境中,在此环境中它们甚至不能切换它们的目录。

在本文中,我们将配置RHEL 6.X 和 CentOS 6.X中的SFTP Chroot环境。我们开启一个用户帐号‘Jack’,该用户将被允许在Linux机器上传输文件,但没有ssh访问权限。

步骤:1 创建组


[root@localhost ~]# groupadd  sftp_users

步骤:2 分配附属组(sftp_users)给用户

如果用户在系统上不存在,使用以下命令创建( LCTT 译注:这里给用户指定了一个不能登录的 shell,以防止通过 ssh 登录):

[root@localhost ~]# useradd  -G sftp_users  -s /sbin/nologin  jack
[root@localhost ~]# passwd jack


对于已经存在的用户,使用以下usermod命令进行修改:


[root@localhost ~]# usermod –G sftp_users  -s /sbin/nologin  jack



注意:如果你想要修改用户的默认家目录,那么可以在useradd和usermod命令中使用‘-d’选项,并设置合适的权限。

步骤:3 现在编辑配置文件 “/etc/ssh/sshd_config”


# vi /etc/ssh/sshd_config
#comment out the below line and add a line like below
#Subsystem sftp /usr/libexec/openssh/sftp-server
Subsystem sftp internal-sftp

# add Below lines  at the end of file
  Match Group sftp_users
  X11Forwarding no
  AllowTcpForwarding no
  ChrootDirectory %h                    
  ForceCommand internal-sftp


此处:

- Match Group sftp_users – 该参数指定以下的行将仅仅匹配sftp_users组中的用户
- ChrootDirectory %h – 该参数指定用户验证后用于chroot环境的路径(默认的用户家目录)。对于用户 Jack,该路径就是/home/jack。
- ForceCommand internal-sftp – 该参数强制执行内部sftp,并忽略任何~/.ssh/rc文件中的命令。

重启ssh服务


# service sshd restart


步骤:4 设置权限:


[root@localhost ~]# chmod 755 /home/jack
[root@localhost ~]# chown root /home/jack
[root@localhost ~]# chgrp -R sftp_users /home/jack


如果你想要允许jack用户上传文件,那么创建一个上传文件夹,设置权限如下:


[root@localhost jack]# mkdir /home/jack/upload
[root@localhost jack]# chown jack. /home/jack upload/


步骤:5 现在尝试访问系统并进行测试

尝试通过ssh访问系统



正如下图所示,用户jack通过SFTP登录,而且因为chroot环境不能切换目录。



现在进行上传和下载测试,如下图:




正如上图所示,jack用户的上传下载功能都工作得很好。
  • 大小: 6.9 KB
  • 大小: 13.3 KB
  • 大小: 15.3 KB
  • 大小: 42.5 KB
分享到:
评论

相关推荐

    linux_ssh命令

    SSH(Secure Shell)是一种网络协议,用于在不安全的网络环境中为网络服务提供安全的环境。SSH 提供两种主要的服务: - **端口转发**:允许远程服务通过本地机器的安全隧道进行访问。 - **X11 转发**:允许用户通过 ...

    Linux系统ssh无密码登录设置手册.pdf

    SSH(Secure Shell)是一种网络安全协议,用于在不安全的网络中为计算机之间加密提供安全的传输通道。SSH通过传输层和用户认证协议提供安全性保证,广泛用于远程登录、远程命令执行、文件传输等。Linux操作系统中的...

    Linux客户端:Xshell5-5.0.1332(教育版)

    Xshell 5.0.1332作为一款优秀的Linux客户端工具,它在Windows环境中为用户提供了强大的Linux命令行操作体验。其丰富的功能、高度的自定义性和安全性,使其成为教学、研究以及日常运维的得力助手。对于那些需要频繁与...

    LINUX-服务器配置实验题(50题).doc

    **背景**: 配置SSH服务,允许root用户登录,并允许特定子网内的主机通过SCP、SFTP等工具进行文件传输。 **解决方案**: - **配置SSH服务**: - 编辑`/etc/ssh/sshd_config`,设置`PermitRootLogin yes`。 - 设置`...

    Xftp-6.0.0187p.exe.7z

    《Xftp 6.0.0187p在...总之,Xftp作为一款强大的文件传输工具,在Linux环境中为用户提供了丰富的功能和良好的用户体验。无论你是开发人员还是运维人员,熟练掌握Xftp的使用技巧,都能显著提升你在文件管理上的效率。

    SHH框架项目实战.txt

    - SSH(Secure Shell)是一种网络安全协议,用于在不安全的网络中为网络服务提供安全的环境,特别是远程登录会话。它由IETF(Internet Engineering Task Force)的网络工作小组(Network Working Group)制定。 - ...

    非对称加密

    SSH(Secure Shell)是一种网络协议,用于在不安全的网络环境中为网络服务提供安全通道。SSH提供了多种加密算法和服务,包括但不限于非对称加密算法。SSH的特点包括: - **安全性**:通过使用非对称加密算法确保...

    finalshell-windows-x64

    总的来说,FinalShell以其强大的功能和用户友好的界面,在Windows环境中为SSH连接和服务器管理提供了优秀的解决方案。无论你是新手还是经验丰富的系统管理员,FinalShell都能成为你日常工作中不可或缺的工具。通过...

    Serv-U Serv-U最新版

    3. **防火墙配置**:在防火墙中为Serv-U打开特定端口,阻止不必要的连接。 4. **日志监控**:定期检查日志,发现异常活动及时处理。 ### 五、故障排查与优化 1. **错误日志分析**:查看Serv-U的日志文件,分析并...

    apache ftp server

    2. **多协议支持**:除了基本的FTP,它还支持FTPS(FTP over SSL/TLS)和SFTP(SSH File Transfer Protocol),提高了数据传输的安全性。 3. **高性能**:Apache FTP Server优化了性能,能够处理大量并发连接,适用...

    centos6.8离线安装ansible包

    本文将深入探讨如何在离线环境中为CentOS 6.8系统安装Ansible包,这对于那些没有互联网连接或者安全策略要求严格的生产环境至关重要。 首先,理解Ansible的基本概念是必要的。Ansible是一个基于Python的开源工具,...

    网络命令行的使用和范例

    - 在远程管理服务器时,使用`ssh`能提供安全的连接,而`scp`或`sftp`则用于安全地传输文件。 总的来说,熟练掌握网络命令行工具对于任何IT专业人员来说都至关重要,它可以帮助我们快速解决问题,提高工作效率,并...

Global site tag (gtag.js) - Google Analytics