免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2590 | 回复: 9
打印 上一主题 下一主题

关于setreuid() [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2012-07-11 16:34 |只看该作者 |倒序浏览

  1.         printf("====before change====\n");
  2.         int eid = geteuid();
  3.         printf("euid = %d\n",eid);
  4.         int rid = getuid();
  5.         printf("ruid = %d\n",rid);

  6.         setreuid(-1,1001);
  7.         printf("====after  change====\n");
  8.         int eidx = geteuid();
  9.         printf("euid = %d\n",eidx);
  10.         int ridx = getuid();
  11.         printf("ruid = %d\n",ridx);
复制代码
运行结果:

====before change====
euid = 1000
ruid = 1000
====after  change====\n");
euid = 1000
ruid = 1000

为什么 setreuid(-1,1001) 没作用???

论坛徽章:
0
2 [报告]
发表于 2012-07-11 18:47 |只看该作者
原来是setreuid(-1,1001)返回了-1,调用失败,怎么解决呢?

论坛徽章:
0
3 [报告]
发表于 2012-07-11 20:23 |只看该作者
经调试,setreuid()要在root下才可以用!

新问题:
倘若代码中有某些操作受限(比如system(rm file) ),怎么在代码中获取这些信息,一旦知道代码中有受限操作就结束掉进程,而不让它运行下去?

论坛徽章:
0
4 [报告]
发表于 2012-07-12 11:23 |只看该作者
回复 3# decimalism

system(3)
    RETURN VALUE
       The value returned is -1 on error (e.g.   fork(2)  failed),  and  the
       return status of the command otherwise.  This latter return status is
       in the format specified in wait(2).  Thus, the exit code of the  com‐
       mand  will be WEXITSTATUS(status).  In case /bin/sh could not be exe‐
       cuted, the exit status will be that of a command that does exit(127).

       If the value of command is NULL,  system()  returns  nonzero  if  the
       shell is available, and zero if not.

       system() does not affect the wait status of any other children.

查看system函数返回值就行了。

论坛徽章:
0
5 [报告]
发表于 2012-07-12 11:49 |只看该作者
回复 4# fdl19881


    不一定调用system,有可能是fopen什么的啊

论坛徽章:
0
6 [报告]
发表于 2012-07-12 12:50 |只看该作者
回复 5# decimalism


    你的意思那是指调用函数不成功了?  判断下返回值就知道是否成功了,,不成功就exit.
是不是这个意思 ?

论坛徽章:
0
7 [报告]
发表于 2012-07-12 13:29 |只看该作者
回复 6# fdl19881


    判断某个进程中是否有读写或执行其他进程的行为,有的话就要终止这个非法进程。
    我将这个进程放在一个最低权限的用户下执行,这些非法操作他就执行不了了,可是这个进程并没有结束。
    现在,我要终止存在非法操作的进程。
    怎么做???

论坛徽章:
95
程序设计版块每日发帖之星
日期:2015-09-05 06:20:00程序设计版块每日发帖之星
日期:2015-09-17 06:20:00程序设计版块每日发帖之星
日期:2015-09-18 06:20:002015亚冠之阿尔艾因
日期:2015-09-18 10:35:08月度论坛发贴之星
日期:2015-09-30 22:25:002015亚冠之阿尔沙巴布
日期:2015-10-03 08:57:39程序设计版块每日发帖之星
日期:2015-10-05 06:20:00每日论坛发贴之星
日期:2015-10-05 06:20:002015年亚冠纪念徽章
日期:2015-10-06 10:06:482015亚冠之塔什干棉农
日期:2015-10-19 19:43:35程序设计版块每日发帖之星
日期:2015-10-21 06:20:00每日论坛发贴之星
日期:2015-09-14 06:20:00
8 [报告]
发表于 2012-07-12 14:41 |只看该作者
decimalism 发表于 2012-07-12 13:29
 现在,我要终止存在非法操作的进程。
    怎么做???


用 kill(3) 发信号

论坛徽章:
0
9 [报告]
发表于 2012-07-12 15:05 |只看该作者
回复 8# MMMIX


    我并不知道哪些进程非法了啊

论坛徽章:
95
程序设计版块每日发帖之星
日期:2015-09-05 06:20:00程序设计版块每日发帖之星
日期:2015-09-17 06:20:00程序设计版块每日发帖之星
日期:2015-09-18 06:20:002015亚冠之阿尔艾因
日期:2015-09-18 10:35:08月度论坛发贴之星
日期:2015-09-30 22:25:002015亚冠之阿尔沙巴布
日期:2015-10-03 08:57:39程序设计版块每日发帖之星
日期:2015-10-05 06:20:00每日论坛发贴之星
日期:2015-10-05 06:20:002015年亚冠纪念徽章
日期:2015-10-06 10:06:482015亚冠之塔什干棉农
日期:2015-10-19 19:43:35程序设计版块每日发帖之星
日期:2015-10-21 06:20:00每日论坛发贴之星
日期:2015-09-14 06:20:00
10 [报告]
发表于 2012-07-12 15:40 |只看该作者
decimalism 发表于 2012-07-12 13:29
回复 6# fdl19881

判断某个进程中是否有读写或执行其他进程的行为,有的话就要终止这个非法进程。


这个你可以看看 SELinux,或者是 Systrace。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP