linux setuid函数_getuid、geteuid和setuid函数 | 学步园

在linux中每个进程有三个[实际上有第4个]用户标识符.

real uid : 真实用户ID.  saved uid : 已保存用户ID , effective uid : 有效用户ID

真实用户ID(real uid)是login时的用户.而在运行过程中,用于所有的安全检查的是有效用户ID(effective uid).

一般情况下:real uid = saved uid = effective uid在某些场合下,使用用setuid,setruid函数可以改变effective uid,从而使得程序运行时具有特殊的权限.常见的例子是linux系统中的passwd命令,由于所有的用户信息包括用户密码都保存在/etc/passwd文件中,而/etc/passwd文件只有root权限可以读写,若想让每个用户都只可以修改自己的密码,就必须让普通用户暂时获得有限的读写/etc/passwd的权限.用setuid就可以解决这个

问题.

Linux setuid(uid)函数:

(1)如果由普通用户调用,将当前进程的有效ID设置为uid.

(2)如果由有效用户ID符为0的进程调用,则将真实,有效和已保存用户ID都设

置为uid.

Linux的setuid函数和Unix中的setuid函数的行为是不同的.

Unix中.setuid(uid)函数的行为:

(1)如果进程没有超级用户特权,且uid等于实际用户ID或已保存用户ID,则只将有效的用户ID设置为uid.否则返回错误.

(2)如果进程是有超级用户特权,则将真实,有效和已保存用户表示符都设置为uid.

这里主要的区别在于普通用户调用时的行为.产生这个问题的原因是POSIX和BSD的实现差异,而linux却同时支持这两者.BSD中使用setreuid(uid_truid, uid_t euid)来设定真实用户ID(real uid)和有效用户ID(effective uid).这个函数在由有效用户ID符为0的进程调用时,不会改变已保存用户ID.函数seteuid(uid_t uid)等价于setreuid(-1,uid),只改变有效用户ID(effective uid).

函数声明:

#include

#include

uid_t getuid(void);

uid_t geteuid(void);

说明:

两个函数分别获得用户 UID值( getuid() ) 与 用户有效 UID 值 ( geteuid())。

测试程序(用 root 用户创建编译并创建可执行文件):

#include

#include

#include

#include

#include

int main()

{

int fd;

printf("uid study: \n");

printf("Process's uid = %d, euid = %d ", getuid(), geteuid());

if( (fd =open("test.txt", O_RDWR)) == -1 )

{

printf("Open failure, errno is %d :%s \n",errno,strerror(errno));

exit(1);

}

Else

{

printf("Open successfully!\n");

}

close(fd);

exit(0);

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值