当前时区为 UTC + 8 小时



发表新帖 回复这个主题  [ 11 篇帖子 ] 
作者 内容
1 楼 
 文章标题 : [问题]关于suid/guid权限位的问题。[已解决]
帖子发表于 : 2007-08-05 9:33 
头像

注册: 2006-07-15 11:20
帖子: 990
地址: 枫叶刀市
送出感谢: 2
接收感谢: 0 次
据我的理解,如果一个程序/脚本被加了suid/guid,那么任何其他用户运行这个程序/脚本时,这个程序/脚本仍然拥有它所属的用户/组的权限。

按网上介绍,suid/guid脚本可以使普通用户执行一些只有root才能执行的操作。

但我新建一个mountntfs.sh
代码:
#!/bin/bash

mount -t ntfs-3g /dev/sda7 /media/sda7


其权限为:
代码:
-rwsr-sr-x  1 root root       52 2007-08-05 01:03 mountntfs.sh


用普通用户运行时为什么还提示“要以root身份运行“?
是我理解错了还是哪里没弄好? :?: 请指点!多谢多谢!


_________________
Thinkpad T400


最后由 Nile 编辑于 2007-08-06 14:27,总共编辑了 1 次

页首
 用户资料  
 
2 楼 
 文章标题 :
帖子发表于 : 2007-08-05 11:10 
头像

注册: 2006-07-15 11:20
帖子: 990
地址: 枫叶刀市
送出感谢: 2
接收感谢: 0 次
晕! :em27 :em27

google了半天终于得到了一个还算过得去的解释:linux does not support suid on scripts.

不至于吧.......


_________________
Thinkpad T400


页首
 用户资料  
 
3 楼 
 文章标题 :
帖子发表于 : 2007-08-05 11:13 
头像

注册: 2006-11-11 10:23
帖子: 1226
地址: Mars
送出感谢: 0 次
接收感谢: 0 次
没必要~~
坚持sudo~~ :lol:


_________________
抬头望星空一片晴,我独行,夜已渐寒……


页首
 用户资料  
 
4 楼 
 文章标题 :
帖子发表于 : 2007-08-05 11:20 
头像

注册: 2006-07-15 11:20
帖子: 990
地址: 枫叶刀市
送出感谢: 2
接收感谢: 0 次
哎,有时候想让系统自动以root权限运行一些东西,又不想用sudo visudo那种方法,没办法呀....


_________________
Thinkpad T400


页首
 用户资料  
 
5 楼 
 文章标题 :
帖子发表于 : 2007-08-05 11:25 
头像

注册: 2005-12-28 1:16
帖子: 3916
地址: 火星
系统: Ubuntu 12.10 X64
送出感谢: 1
接收感谢: 0 次
写一个C的wrapper
#include <stdlib.h>

int main( )
{
system("命令");
}


_________________
目前负债150多万


页首
 用户资料  
 
6 楼 
 文章标题 :
帖子发表于 : 2007-08-05 11:33 
头像

注册: 2006-11-11 10:23
帖子: 1226
地址: Mars
送出感谢: 0 次
接收感谢: 0 次
开机运行?把脚本加到rc.local就行了


_________________
抬头望星空一片晴,我独行,夜已渐寒……


页首
 用户资料  
 
7 楼 
 文章标题 :
帖子发表于 : 2007-08-05 11:37 
头像

注册: 2006-07-15 11:20
帖子: 990
地址: 枫叶刀市
送出感谢: 2
接收感谢: 0 次
xhy 写道:
写一个C的wrapper
#include <stdlib.h>

int main( )
{
system("命令");
}


谢谢,准备试一试。

引用:
开机运行?把脚本加到rc.local就行了


Thanks 这个试过了,同样的命令(比如那个mountntfs的shell)用rc.local不能正确执行,但手动可以,奇载怪也 :D


_________________
Thinkpad T400


页首
 用户资料  
 
8 楼 
 文章标题 :
帖子发表于 : 2007-08-06 12:53 
头像

注册: 2006-07-15 11:20
帖子: 990
地址: 枫叶刀市
送出感谢: 2
接收感谢: 0 次
xhy 写道:
写一个C的wrapper
#include <stdlib.h>

int main( )
{
system("命令");
}


试了一下,和shell结果一样,加不加suid位看不出任何区别!

难道ubuntu根本不支持suid/guid?(网上说有些系统为了确保安全会这样做)

:em69

请高人指点一二!!!


_________________
Thinkpad T400


页首
 用户资料  
 
9 楼 
 文章标题 :
帖子发表于 : 2007-08-06 13:45 
头像

注册: 2005-12-28 1:16
帖子: 3916
地址: 火星
系统: Ubuntu 12.10 X64
送出感谢: 1
接收感谢: 0 次
system之前还没setuid呢
要用root执行就setuid(0);


_________________
目前负债150多万


页首
 用户资料  
 
10 楼 
 文章标题 :
帖子发表于 : 2007-08-06 14:26 
头像

注册: 2006-07-15 11:20
帖子: 990
地址: 枫叶刀市
送出感谢: 2
接收感谢: 0 次
终于搞定了! :D :D

谢谢xhy兄的大力帮助 :em50 :em50

下面是代码,以伺后观人风者得焉......
代码:
//The runcmd.cpp file
#include<stdlib.h>
#include<sys/types.h>
#include<unistd.h>

using namespace std;

int main()
{
   setuid(0);
   system("sudo mount -t ntfs-3g /dev/sda7 /media/sda7");
}


代码:
-rwsr-xr-x 1 root root 7261 2007-08-06 14:02 runcmd


_________________
Thinkpad T400


页首
 用户资料  
 
11 楼 
 文章标题 : Re: [问题]关于suid/guid权限位的问题。[已解决]
帖子发表于 : 2012-03-06 22:59 

注册: 2011-04-02 12:06
帖子: 2
送出感谢: 0 次
接收感谢: 0 次
非常感谢,我也遇到这样的问题。


页首
 用户资料  
 
显示帖子 :  排序  
发表新帖 回复这个主题  [ 11 篇帖子 ] 

当前时区为 UTC + 8 小时


在线用户

正在浏览此版面的用户:没有注册用户 和 4 位游客


不能 在这个版面发表主题
不能 在这个版面回复主题
不能 在这个版面编辑帖子
不能 在这个版面删除帖子
不能 在这个版面提交附件

前往 :  
本站点为公益性站点,用于推广开源自由软件,由 DiaHosting VPSBudgetVM VPS 提供服务。
我们认为:软件应可免费取得,软件工具在各种语言环境下皆可使用,且不会有任何功能上的差异;
人们应有定制和修改软件的自由,且方式不受限制,只要他们自认为合适。

Powered by phpBB © 2000, 2002, 2005, 2007 phpBB Group
简体中文语系由 王笑宇 翻译