V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
Newyorkcity
V2EX  ›  问与答

初学 Linux ,请教一个 SUID 的问题

  •  
  •   Newyorkcity · 2019-07-06 10:35:34 +08:00 · 1008 次点击
    这是一个创建于 1944 天前的主题,其中的信息可能已经有所发展或是发生改变。
    一个二进制程序

    ---s------ (-rws------)

    ---s-----x (-rws---rwx)

    ---x-----x (-rwx---rwx)

    这三者有区别么?如果三者有区别,各自最优的应用场景是?

    谢谢
    3 条回复    2019-07-06 17:17:11 +08:00
    msg7086
        1
    msg7086  
       2019-07-06 14:37:55 +08:00   ❤️ 1
    s 是 setuid 标志位,就是任何能执行这个程序的人,执行这个程序的时候都自动切换到这个文件的所属用户。
    比如 sudo 程序就是 setuid 且属于 root 的,所以任何人执行 sudo 都会自动让程序运行在 root 权限上。

    你这 3 个例子。
    rws 没意义因为别人无法执行这个程序。
    rws---rwx 可以让任何人通过所属用户权限执行。当然也可以肆意修改这个程序。
    rwx---rwx 可以让任何人正常执行程序,当然也可以肆意修改这个程序。

    应用场景的话,这 3 个权限组合都没有应用场景,正常人不会用的。
    Newyorkcity
        2
    Newyorkcity  
    OP
       2019-07-06 16:05:26 +08:00
    请问 SUID 和将其它用户的权限+x 有何区别呢?
    tempdban
        3
    tempdban  
       2019-07-06 17:17:11 +08:00 via Android
    @Newyorkcity 提示:fork
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   5220 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 32ms · UTC 09:30 · PVG 17:30 · LAX 02:30 · JFK 05:30
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.