`
jubincn
  • 浏览: 233193 次
  • 性别: Icon_minigender_1
  • 来自: 宁波
文章分类
社区版块
存档分类
最新评论

setuid函数的学习笔记 转自:http://blog.chinaunix.net/space.php?uid=1877180&do=blog&cuid=1132108

 
阅读更多

转自:http://blog.chinaunix.net/space.php?uid=1877180&do=blog&cuid=1132108


在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_t ruid, uid_t euid)
来设定真实用户ID(real uid)和有效用户ID(effective uid).这个函数在由有效
用户ID符为0的进程调用时,不会改变已保存用户ID.函数seteuid(uid_t uid)等价
于setreuid(-1,uid),只改变有效用户ID(effective uid).


例子:
使用setuid或是setruid,让非root用户也可以读取只有root用户有读写权限的
文件.

#假设此程序名为:setuid_ex
#要读取的文件为:root_only.txt
$ users
dd admin
$ ls -l root_only.txt
-rw------- 1 root root 33 Jan 11 17:07 root_only.txt
$ vi setuid_ex.cpp
1 /**
2 * Linux setuid函数的例子.
3 * */
4 #include <unistd.h> //setuid() and getuid()
5 #include <iostream>
6 #include <fstream>
7
8 using namespace std;
9 void test_read_file(const char *name)
10 {
11 ifstream f(name);
12 if(f.fail())
13 cout<<"=[ERROR]: read failed."<<endl;
14 else
15 cout<<"=[OK]: read successful."<<endl;
16 }
17 //打印uid和euid.
18 inline void p_states(void)
19 {
20 int uid,euid;
21 cout<<"-----Current states--------------------------"<<endl;
22 cout<<"real uid\t"<<getuid()<<endl;
23 cout<<"effective uid\t"<<geteuid()<<endl;
24 cout<<"---------------------------------------------"<<endl;
25 }
26 //调用setuid.
27 inline void run_setuid_fun(int uid)
28 {
29 if(setuid(uid) == -1)
30 cout<<"=[ERROR]: setuid("<<uid<<") error"<<endl;
31 p_states();
32 }
33 //调用seteuid.
34 inline void run_seteuid_fun(int uid)
35 {
36 if(seteuid(uid) == -1)
37 cout<<"=[ERROR]: seteuid("<<uid<<") error"<<endl;
38 p_states();
39 }
40
41 int main()
42 {
43 int t_re=0;
44 const char * file = "root_only.txt";
45
46 cout<<endl<<"TEST 1: "<<endl;
47 p_states();
48 //[1]此时 real uid= login user id
49 // effective uid = root
50 // saved uid = root
51 test_read_file(file);
52
53 cout<<endl<<"TEST 2: seteuid(getuid())"<<endl;
54 run_seteuid_fun(getuid());
55 //[2]此时 real uid= login user id
56 // effective uid = login user id
57 // saved uid = root
58 test_read_file(file);
59
60 cout<<endl<<"TEST 3: seteuid(0)"<<endl;
61 run_seteuid_fun(0);
62 //[3]此时 real uid= login user id
63 // effective uid = root
64 // saved uid = root
65 test_read_file(file);
66
67 cout<<endl<<"TEST 4: setuid(0)"<<endl;
68 run_setuid_fun(0);
69 //[4]此时 real uid= root
70 // effective uid = root
71 // saved uid = root
72 test_read_file(file);
73
74 cout<<endl<<"TEST 5: setuid(503)"<<endl;
75 run_setuid_fun(503);
76 //[5]此时 real uid= login user id
77 // effective uid = login user id
78 // saved uid = login user id
79 test_read_file(file);
80
81 cout<<endl<<"TEST 6: setuid(0)"<<endl;
82 //[6]此时 real uid= login user id
83 // effective uid = login user id
84 // saved uid = login user id
85 // 运行setuid(0)是将返回错误值-1.
86 run_setuid_fun(0);
87 test_read_file(file);
88 return 0;
89 }
90
91
$ vi Makefile
1 src=setuid_ex.cpp
2 exe=setuid_ex
3 cc=g++
4 flags=-g
5
6 all:${src}
7 ${cc} ${flags} -o ${exe}
8 chown root:root ${exe}
9 ### 实际上chmod 4111改变了effective id 和saved uid的值.
10 ### 这也是setuid setruid函数在不同权限间正常切换的前提.
11 chmod 4111 ${exe}

$ sudo make #使用root进行Make.
$ ls -l setuid_ex
---s--x--x 1 root root 58579 Jan 15 11:27 setuid_ex
$ ./setuid_ex
TEST 1:
-----Current states--------------------------
real uid 503
effective uid 0
---------------------------------------------
=[OK]: read successful.

TEST 2: seteuid(getuid())
-----Current states--------------------------
real uid 503
effective uid 503
---------------------------------------------
=[ERROR]: read failed.

TEST 3: seteuid(0)
-----Current states--------------------------
real uid 503
effective uid 0
---------------------------------------------
=[OK]: read successful.

TEST 4: setuid(0)
-----Current states--------------------------
real uid 0
effective uid 0
---------------------------------------------
=[OK]: read successful.

TEST 5: setuid(503)
-----Current states--------------------------
real uid 503
effective uid 503
---------------------------------------------
=[ERROR]: read failed.

TEST 6: setuid(0)
=[ERROR]: setuid(0) error
-----Current states--------------------------
real uid 503
effective uid 503
---------------------------------------------
=[ERROR]: read failed.
分享到:
评论

相关推荐

    开源时代(1-10)

    由于文件太大,分两部分:...http://linux.chinaunix.net/bbs/attachment.php?aid=214186 《开源时代》2008.10(第二期) http://linux.chinaunix.net/bbs/attachment.php?aid=219853 《开源时代》2008.11(第三期) ...

    开源时代(11-16)

    这是第十一期到第十六期,...http://linux.chinaunix.net/bbs/attachment.php?aid=214186 《开源时代》2008.10(第二期) http://linux.chinaunix.net/bbs/attachment.php?aid=219853 《开源时代》2008.11(第三期) ...

    蓝牙串口聊天

    参考博文创建,详细解释参考:http://blog.chinaunix.net/uid-7552018-id-173419.html 3.安卓3.0以上使用自定义title时要注销默认title,详细参考:...

    IOMSV1.10_alpha版本程序包1/3

    个人技术网站:http://hawkli.blog.chinaunix.net IOMS源站点: http://code.google.com/p/ioms/ IOMS全称为Integrated Operation Management System集中运维管理系统,是一个类似于Fedora统一网络控制器FUNC这样的...

    IOMSV1.10_alpha程序包2/3

    个人技术网站:http://hawkli.blog.chinaunix.net IOMS源站点: http://code.google.com/p/ioms/ IOMS全称为Integrated Operation Management System集中运维管理系统,是一个类似于Fedora统一网络控制器FUNC这样的...

    URLTester

    URLTester是一个URL测试工具,最主要的一个特色是:当一个域名对应... 网址:http://blog.chinaunix.net/u2/64804/showart_1132881.html&lt;br&gt;下载:http://blogimg.chinaunix.net/blog/upfile2/080818094844.zip&lt;br&gt;

    IOMSV1.10_alpha程序包3/3

    个人技术网站:http://hawkli.blog.chinaunix.net IOMS源站点: http://code.google.com/p/ioms/ IOMS全称为Integrated Operation Management System集中运维管理系统,是一个类似于Fedora统一网络控制器FUNC这样的...

    dos下的win31图形界面基础组件源程序

    http://bbs.chinaunix.net/viewthread.php?tid=942230 源代码下载:http://www.cn-dos.net/forum/atta ... c12e&download=1 https://gro.clinux.org/frs/download.php/2035/giCell_20070713.rar 演示下载:...

    CSocket 聊天室源码(不使用派生类)(VS2013)

    不过网上有一篇流传很广的文章(http://blog.chinaunix.net/uid-20743151-id-326359.html),里面有一句“CSocket经常不用派生就可以直接使用”,这个程序演示了这种用法。代码已使用 Visual Studio 2013 调试编译...

    Linux上用udev自动识别并挂载U盘

    根据网上了解,可以通过udev来实现U盘的自动识别和挂载,操作方法...http://blog.chinaunix.net/uid-26119896-id-5211736.html (u盘挂载) http://www.cnblogs.com/sopost/archive/2013/01/09/2853200.html (udev简介)

    Windows下MySQL自动下载安装小工具包(更新)V1.2

    http://blog.chinaunix.net/uid/40286.html http://blog.chinaunix.net/topic/hexiong/ ===================================================================================================== 示例: :: ...

    apache+mysql+php+snort+base实现snort

    主要参照www.chinaunix.net和www.snort.org上面的相关文档,特别感谢www.chinaunix.net上面的两个作者,我是在他们的基础上测试成功的,主要有下面两篇文档http://linux.chinaunix.net/bbs/viewthread.php?...

    CopyPath v1.0, Copy paths of the selected files, (新增右键支持复制多文件路径)

    http://blog.chinaunix.net/u/8754/showart_1961481.html Important Notice: Althouth there are no malicious codes included, I do not issue any guarantee of any kind, use it at your own risk!

    TCP_IP.zip

    本代码实现了使用Python通过TCP/IP方式对SWIESS温箱的温度控制和查询等功能,实现了SWIESS温箱的自动化控制,完成了代码调试,也适用于其他温箱的TCP/IP方式的控制

    libjpeg.so.62.0.0.rar

    小程序在:http://blog.chinaunix.net/u3/93660/showart_1860238.html 1、交叉编译: #arm-linux-gcc test.c -o test -I /usr/local/arm/3.4.1/arm-linux/include -L /usr/local/arm/3.4.1/arm-linux/lib 2、将...

    [shell编程]Linux环境下通用文本型日志的监控和收集

    因工作需要写了一个Linux环境下的文本日志收集程序,学习并实践了一回shell编程。 比起那些Java写的监控程序,shell脚本算是绿色环保了。...程序讨论和更新:http://bbs3.chinaunix.net/viewthread.php?tid=1586069

    写得蛮好的linux学习笔记

    写得蛮好的linux学习笔记 &lt;br&gt; 转http://blog.chinaunix.net/u/30619/showart.php?id=249558&lt;br&gt;

    博客珍藏工具 1.2.2

    Blog_Backup支持国内所有大型BSP,可导出内容为多种格式(RSS//Atom/...http://blog.chinaunix.net/u/19103/guestbook.html 反馈问题时请提供当前版本号:1.2.2(200908241521) PT42新作品:网页净化器~欢迎试用~

    jflash烧写软件 支持wigger

    支持wigger的jflash ... 两篇博文介绍得很详细啦,http: //blog.chinaunix.net/u/24474/showart_227846.html 和 http://blog.chinaunix.net/u/23070/showart.php?id=157735;

Global site tag (gtag.js) - Google Analytics