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 / 问题 / 504919
Accepted
dmourati
dmourati
Asked: 2013-05-04 13:30:10 +0800 CST2013-05-04 13:30:10 +0800 CST 2013-05-04 13:30:10 +0800 CST

在 sftp 上禁止 -p

  • 772

我们有一台服务器充当(外部)用户的“投递箱”,通过 sftp/ssh 向我们上传数据。我们需要在这些文件进来时对其进行处理(gpg 解密、解压缩等)。过去,我们只是简单地处理每个用户主目录中的每个文件,而不管我们是否已经处理过它。结果证明这是浪费。我更新(重写)了我们的处理脚本以依赖如下机制:

FILESTOPROCESS=$(find -H /home/$CUST -type f -newer /home/$CUST/marker-file)

这与 a 相结合touch /home/$CUST/marker-file效果很好,我们的工作量大大减少了。

大约一天前,我们的 SSH 服务器出现配置问题,暂时不允许用户向我们上传文件。当脚本再次运行时,它忽略了用户最初未能上传的文件,但随后使用“-p”选项通过 sftp/ssh 上传,以保留时间戳。这将文件的 c/a/mtimes 设置为比标记文件早一天左右,因此随后被忽略。

我想禁止用户使用“-p”上传,以便使用当前时间戳创建文件。

我可以在 sshd_config 中执行此操作吗?

ssh
  • 4 4 个回答
  • 1478 Views

4 个回答

  • Voted
  1. Best Answer
    Dennis Kaarsemaker
    2013-05-07T13:11:24+08:002013-05-07T13:11:24+08:00

    不,您不能在配置中执行此操作。仔细查看sftp-server.c,我看到禁用它的唯一方法是sftp-server在只读模式下运行,如果你想允许上传,这是非常无用的:)

    如果您不介意维护自己的 openssh 包,则可以在编译前删除对utimes/ futimesin的调用。sftp-server.c或者,您可以使用LD_PRELOAD带有这些函数的 noop 实现的库。

    • 6
  2. Mircea Vutcovici
    2013-05-07T13:18:12+08:002013-05-07T13:18:12+08:00

    您可以使用 incond(inotify cron 守护进程)在添加文件时触发脚本。

    如果一次上传的文件很多,可以将需要处理的文件名排队,然后一个一个处理队列中的项目。

    • 4
  3. PhilR
    2013-05-08T04:51:27+08:002013-05-08T04:51:27+08:00

    你说... "-p" option ... set the c/a/mtimes of the file ...- 这是不正确的,因为 ctime 只能通过更改 inode mtime 或权限(或此处不相关的其他 inode 设置)设置为当前时间。

    有了这些知识,您就可以使用 找到未处理的文件-cnewer。

    $ FILESTOPROCESS=$(find -H /home/$CUST -type f \
       \( -newer /home/$CUST/marker-file -o \
          -cnewer /home/$CUST/marker-file \) )
    
    • 2
  4. David W
    2013-05-07T13:14:57+08:002013-05-07T13:14:57+08:00

    我不知道(但我不认为)您是否可以在 sshd_config 中完成此操作。但是,这里有一个想法:如果您修改处理脚本以便文件首先进入临时目录,您可以获取文件的哈希值(也许是 md5),并将该哈希值与目录中具有相同名称的文件进行比较用户的目录(如果存在这样的文件)。

    如果哈希匹配,则什么都不做(有什么意义?)

    如果散列不匹配,则将文件从临时目录复制(不要移动)到最终位置(当然不带 -p 选项)。

    • 1

相关问题

  • 如何最好地设置 ssh 隧道以访问远程网络 (Linux)

  • SSH 和重定向

  • 通过 SSH 会话使用 NET USER 命令拒绝访问

  • SSH 服务器零日漏洞利用 - 保护自己的建议

  • ubuntu apt-get upgrade - 如何在 shell 中单击确定?

Sidebar

Stats

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

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

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

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

    • 9 个回答
  • Marko Smith

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

    • 3 个回答
  • Marko Smith

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

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +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