AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 122877
Accepted
Chen Levy
Chen Levy
Asked: 2010-03-17 02:22:11 +0800 CST2010-03-17 02:22:11 +0800 CST 2010-03-17 02:22:11 +0800 CST

将 vsftpd 上传限制为给定的一组文件名

  • 772

我需要配置一个匿名 ftp 上传。鉴于此要求,我尝试将此服务器锁定到最低限度。

我希望施加的限制之一是只允许上传一组给定的文件名。

我试图禁止对上传文件夹的写权限,并在其中放入一些具有写权限的空文件:

/var/ftp/         [root.root] [drwxr-xr-x]
|-- upload/       [root.root] [drwxr-xr-x]
|   |-- upfile1   [ftp.ftp]   [--w-------]
|   `-- upfile2   [ftp.ftp]   [--w-------]
`-- download/     [root.root] [drwxr-xr-x]
    `-- ...

但是这种方法不起作用,因为当我尝试上传时upfile1,它试图删除并在其位置创建一个新文件,并且没有权限。

有没有办法让这项工作,或者可能使用不同的方法,比如滥用deny_file选项?

ftp
  • 1 1 个回答
  • 1704 Views

1 个回答

  • Voted
  1. Best Answer
    Chen Levy
    2010-03-19T05:18:41+08:002010-03-19T05:18:41+08:00

    好的,我已经解决了这个问题:

    在/etc/vsftpd/vsftpd.conf添加行:

    anon_other_write_enable=YES
    

    来自man vsftpd.conf (5):

    anon_other_write_enable 
    

    如果设置为 YES,匿名用户将被允许执行除上传和创建目录之外的写操作,例如删除和重命名。通常不建议这样做,但为了完整性而包含在内。

    默认:NO

    那么,ftp文件的布局应该是:

    /var/ftp/         [root.root]   [drwxr-xr-x]
    |-- upload/       [root.root]   [drwxr-x--x]
    |   |-- upfile1   [ftp.users]   [--w-r-----]
    |   `-- upfile2   [ftp.users]   [--w-r-----]
    ...
    

    目录的其他--x权限upload/是这里的关键:

    • r- 将允许列出目录内容
    • w- 将允许创建和删除文件
    • x- 将允许读/写现有文件。

    最后,ftp所有者-w-文件权限不允许匿名用户下载该文件,而本地用户r--可以读取该文件。


    如果我在这里向我错过的一些攻击向量敞开心扉,请在下面发表评论。

    • 0

相关问题

  • 知道任何适用于 Windows 的快速可编写脚本的 ftp 客户端吗?[关闭]

  • 无法连接到我的 FTP 服务器,为什么?

  • 无法再连接到 FTP 站点

  • 您更喜欢哪个 FTP 客户端,为什么?

  • XP下设置FTP服务器时出错

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    从 IP 地址解析主机名

    • 8 个回答
  • Marko Smith

    如何按大小对 du -h 输出进行排序

    • 30 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    MikeN 在 Nginx 中,如何在维护子域的同时将所有 http 请求重写为 https? 2009-09-22 06:04:43 +0800 CST
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    0x89 bash中的双方括号和单方括号有什么区别? 2009-08-10 13:11:51 +0800 CST
  • Martin Hope
    Kyle Brandt IPv4 子网如何工作? 2009-08-05 06:05:31 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve