亚洲av成人无遮挡网站在线观看,少妇性bbb搡bbb爽爽爽,亚洲av日韩精品久久久久久,兔费看少妇性l交大片免费,无码少妇一区二区三区

  免費(fèi)注冊(cè) 查看新帖 |

Chinaunix

  平臺(tái) 論壇 博客 文庫
最近訪問板塊 發(fā)新帖
查看: 2100 | 回復(fù): 0
打印 上一主題 下一主題

linux下的setuid等函數(shù) [復(fù)制鏈接]

論壇徽章:
0
跳轉(zhuǎn)到指定樓層
1 [收藏(0)] [報(bào)告]
發(fā)表于 2010-01-26 21:08 |只看該作者 |倒序?yàn)g覽
                                                                     
    在linux中每個(gè)進(jìn)程有三個(gè)[實(shí)際上有第4個(gè)]用戶標(biāo)識(shí)符.
        real uid      : 真實(shí)用戶ID.
        saved uid     : 已保存用戶ID
        effective uid : 有效用戶ID
    真實(shí)用戶ID(real uid)是login時(shí)的用戶.而在運(yùn)行過程中,
用于所有的安全檢查的是有效用戶ID(effective uid).
一般情況下:
    real uid = saved uid = effective uid
    在某些場(chǎng)合下,使用用setuid,setruid函數(shù)可以改變effective uid,從而
使得程序運(yùn)行時(shí)具有特殊的權(quán)限.常見的例子是linux系統(tǒng)中的passwd命令,
由于所有的用戶信息包括用戶密碼都保存在/etc/passwd文件中,而/etc/passwd
文件只有root權(quán)限可以讀寫,若想讓每個(gè)用戶都只可以修改自己的密碼,就必須
讓普通用戶暫時(shí)獲得有限的讀寫/etc/passwd的權(quán)限.用setuid就可以解決這個(gè)
問題.
Linux setuid(uid)函數(shù):
    (1)如果由普通用戶調(diào)用,將當(dāng)前進(jìn)程的有效ID設(shè)置為uid.
    (2)如果由有效用戶ID符為0的進(jìn)程調(diào)用,則將真實(shí),有效和已保存用戶ID都設(shè)
    置為uid.
Linux的setuid函數(shù)和Unix中的setuid函數(shù)的行為是不同的.
Unix中.setuid(uid)函數(shù)的行為:
    (1)如果進(jìn)程沒有超級(jí)用戶特權(quán),且uid等于實(shí)際用戶ID或已保存用戶ID,則只
    將有效的用戶ID設(shè)置為uid.否則返回錯(cuò)誤.
    (2)如果進(jìn)程是有超級(jí)用戶特權(quán),則將真實(shí),有效和
    已保存用戶表示符都設(shè)置為uid.
    這里主要的區(qū)別在于普通用戶調(diào)用時(shí)的行為.產(chǎn)生這個(gè)問題的原因是POSIX和
BSD的實(shí)現(xiàn)差異,而linux卻同時(shí)支持這兩者.BSD中使用
            setreuid(uid_t ruid, uid_t euid)
來設(shè)定真實(shí)用戶ID(real uid)和有效用戶ID(effective uid).這個(gè)函數(shù)在由有效
用戶ID符為0的進(jìn)程調(diào)用時(shí),不會(huì)改變已保存用戶ID.函數(shù)seteuid(uid_t uid)等價(jià)
于setreuid(-1,uid),只改變有效用戶ID(effective uid).
例子:
  使用setuid或是setruid,讓非root用戶也可以讀取只有root用戶有讀寫權(quán)限的
文件.
#假設(shè)此程序名為:setuid_ex
#要讀取的文件為:root_only.txt 我修改改寫了一個(gè)c語言版本:
view plain
copy to clipboard
print
?
/*  * linux setuid example  * */  #include  #include  #include  void test_read_file(const char *name)  {      int fd = -1;      fd = open(name, O_RDWR);      if(fd     {          printf("=[ERROR]:read failed.\n");      }      else      {          printf("=[OK]: read fuccessful\n");          close(fd);      }        }  //打印uid和euid.  void p_states(void)  {      int uid = 0;      int euid = 0;      printf("-----Current states--------------------------\n");      printf("real uid\t %d\n",getuid());      printf("effective uid\t %d\n",geteuid());      printf("---------------------------------------------\n");  }  //調(diào)用setuid  void run_setuid_fun(int uid)  {      if(setuid(uid) == -1)      {          printf("=[ERROR]:setuid(%d) error\n", uid);      }      p_states();  }  //調(diào)用seteuid  void run_seteuid_fun(int uid)  {      if(seteuid(uid)== -1)      {          printf("=[ERROR]:seteuid(%d) error\n", uid);      }      p_states();  }  int main()  {      int t_re = 0;      const char *file = "root_only.txt";      printf("\nTEST 1:\n");      p_states();      //此時(shí)real uid = login user id      //effective uid = root      //saved uid = root      test_read_file(file);      printf("\nTEST 2:seteuid(getuid())\n");      run_seteuid_fun(getuid());      //[2]此時(shí) real uid= login user id          //     effective uid = login user id          //     saved uid = root          test_read_file(file);      printf("\nTEST 3:seteuid(0)\n");      run_seteuid_fun(0);      //read uid = lonin user id      //effective uid = root      //saved uid = root      test_read_file(file);      printf("\nTEST 4:setuid(0)\n");      run_setuid_fun(0);      //real uid = root      //effective uid = root      //saved uid= root      test_read_file(file);            printf("\nTEST 5 setuid(503)\n");      run_setuid_fun(503);      //real uid = login user id      //effective id = login user id      //saved uid = login user id      test_read_file(file);      printf("\nTEST 6:seruid(0)\n");      //read uid = login user id      //effective uid = login user id      //saved uid = login user id      run_setuid_fun(0);      test_read_file(file);      return 0;  }   makefile 需要在root權(quán)限下編譯,在用戶權(quán)限進(jìn)行執(zhí)行。
view plain
copy to clipboard
print
?
src=setuid_ex.c  exe=setuid_ex  cc=gcc  flags=-g  all:      ${cc} ${flags} $(src) -o ${exe}      chown root:root ${exe}  ### 實(shí)際上chmod 4111改變了effective id 和saved uid的值.  ### 這也是setuid setruid函數(shù)在不同權(quán)限間正常切換的前提.      chmod 4111 ${exe}
               
               
               
               

本文來自ChinaUnix博客,如果查看原文請(qǐng)點(diǎn):http://blog.chinaunix.net/u2/72255/showart_2161592.html
您需要登錄后才可以回帖 登錄 | 注冊(cè)

本版積分規(guī)則 發(fā)表回復(fù)

  

北京盛拓優(yōu)訊信息技術(shù)有限公司. 版權(quán)所有 京ICP備16024965號(hào)-6 北京市公安局海淀分局網(wǎng)監(jiān)中心備案編號(hào):11010802020122 niuxiaotong@pcpop.com 17352615567
未成年舉報(bào)專區(qū)
中國互聯(lián)網(wǎng)協(xié)會(huì)會(huì)員  聯(lián)系我們:huangweiwei@itpub.net
感謝所有關(guān)心和支持過ChinaUnix的朋友們 轉(zhuǎn)載本站內(nèi)容請(qǐng)注明原作者名及出處

清除 Cookies - ChinaUnix - Archiver - WAP - TOP