1. endgrent(关闭组文件)
  2. 相关函数
  3. getgrentsetgrent
  4. 表头文件
  5. #include<grp.h>
  6. #include<sys/types.h>
  7. 定义函数
  8. void endgrent(void);
  9. 函数说明
  10. endgrent()用来关闭由getgrent()所打开的密码文件。
  11. 返回值
  12.  
  13. 附加说明
  14.  
  15. 范例
  16. 请参考getgrent()与setgrent()。
  17.  
  18.  
  19. endpwent(关闭密码文件)
  20. 相关函数
  21. getpwentsetpwent
  22. 表头文件
  23. #include<pwd.h>
  24. #include<sys/types.h>
  25. 定义函数
  26. void endpwent(void);
  27. 函数说明
  28. endpwent()用来关闭由getpwent()所打开的密码文件。
  29. 返回值
  30.  
  31. 附加说明
  32.  
  33. 范例
  34. 请参考getpwent()与setpwent()。
  35.  
  36.  
  37. endutent(关闭utmp 文件)
  38. 相关函数
  39. getutentsetutent
  40. 表头文件
  41. #include<utmp.h>
  42. 定义函数
  43. void endutent(void);
  44. 函数说明
  45. endutent()用来关闭由getutent所打开的utmp文件。
  46. 返回值
  47.  
  48. 附加说明
  49.  
  50. 范例
  51. 请参考getutent()。
  52.  
  53.  
  54. fgetgrent(从指定的文件来读取组格式)
  55. 相关函数
  56. fgetpwent
  57. 表头文件
  58. #include<grp.h>
  59. #include<stdio.h>
  60. #include<sys/types.h>
  61. 定义函数
  62. struct group * getgrent(FILE * stream);
  63. 函数说明
  64. fgetgrent()会从参数stream指定的文件读取一行数据,然后以group结构将该数据返回。参数stream所指定的文件必须和、etc/group相同的格式。group结构定义请参考getgrent()。
  65. 返回值
  66. 返回group结构数据,如果返回NULL则表示已无数据,或有错误发生。
  67. 范例
  68. #include <grp.h>
  69. #include<sys/types.h>
  70. #include<stdio.h>
  71. main()
  72. {
  73. struct group *data;
  74. FILE *stream;
  75. int i;
  76. stream = fopen("/etc/group", "r");
  77. ){
  78. i=;
  79. printf("%s :%s:%d :", data->gr_name,data->gr_passwd,data->gr_gid);
  80. while (data->gr_mem[i])printf("%s,",data->gr_mem[i++]);
  81. printf("\n");
  82. }
  83. fclose(stream);
  84. }
  85. 执行
  86. root:x::root,
  87. bin:x::root,bin,daemon
  88. daemon:x::root,bin,daemon
  89. sys:x::root,bin,adm
  90. adm:x::root,adm,daemon
  91. tty:x:
  92. disk:x::root
  93. lp:x::daemon,lp
  94. mem:x:
  95. kmem:x:
  96. wheel:x::root
  97. mail:x::mail
  98. news:x::news
  99. uucp:x::uucp
  100. man:x:
  101. games:x:
  102. gopher:x:
  103. dip:x::
  104. ftp:x:
  105. nobody:x::
  106.  
  107.  
  108. fgetpwent(从指定的文件来读取密码格式)
  109. 相关函数
  110. fgetgrent
  111. 表头文件
  112. #include<pwd.h>
  113. #include<stdio.h>
  114. #include<sys/types.h>
  115. 定义函数
  116. struct passwd * fgetpwent(FILE *stream);
  117. 函数说明
  118. fgetpwent()会从参数stream指定的文件读取一行数据,然后以passwd结构将该数据返回。参数stream所指定的文件必须和/etc/passwd相同的格式。passwd结构定义请参考getpwent()。
  119. 返回值
  120. 返回passwd结构数据,如果返回NULL则表示已无数据,或有错误发生。
  121. 范例
  122. #include<pwd.h>
  123. #include<sys/types.h>
  124. main()
  125. {
  126. struct passwd *user;
  127. FILE *stream;
  128. stream = fopen("/etc/passwd", "r");
  129. ){
  130. printf("%s:%d:%d:%s:%s:%s\n",user->pw_name,user->pw_uid,user->pw_gid,user->pw_gecos,user->pw_dir,user->pw_shell);
  131. }
  132. }
  133. 执行
  134. root:::root:/root:/bin/bash
  135. bin:::bin:/bin:
  136. daemon:::daemon:/sbin:
  137. adm:::adm:/var/adm:
  138. lp:::lp:/var/spool/lpd:
  139. sync:::sync:/sbin:/bin/sync
  140. shutdown:::shutdown:/sbin:/sbin/shutdown
  141. halt:::halt:/sbin:/sbin/halt
  142. mail:::mail:/var/spool/mail:
  143. news:::news:var/spool/news
  144. uucp:::uucp:/var/spool/uucp:
  145. ::operator :/root:
  146. games:::games:/usr/games:
  147. gopher:::gopher:/usr/lib/gopher-data:
  148. ftp:::FTP User:/home/ftp:
  149. nobody:::Nobody:/:
  150. xfs:::X Font Server: /etc/Xll/fs:/bin/false
  151. gdm:::/home/gdm:/bin/bash
  152. kids::: : /home/kids:/bin/bash
  153.  
  154.  
  155. getegid(取得有效的组识别码)
  156. 相关函数
  157. getgidsetgidsetregid
  158. 表头文件
  159. #include<unistd.h>
  160. #include<sys/types.h>
  161. 定义函数
  162. gid_t getegid(void);
  163. 函数说明
  164. getegid()用来取得执行目前进程有效组识别码。有效的组识别码用来决定进程执行时组的权限。返回值返回有效的组识别码。
  165. 范例
  166. main()
  167. {
  168. printf("egid is %d\n",getegid());
  169. }
  170. 执行
  171. egid /*当使用root身份执行范例程序时*/
  172.  
  173.  
  174. geteuid(取得有效的用户识别码)
  175. 相关函数
  176. getuidsetreuidsetuid
  177. 表头文件
  178. #include<unistd.h>
  179. #include<sys/types.h>
  180. 定义函数
  181. uid_t geteuid(void)
  182. 函数说明
  183. geteuid()用来取得执行目前进程有效的用户识别码。有效的用户识别码用来决定进程执行的权限,借由此改变此值,进程可以获得额外的权限。倘若执行 文件的setID位已被设置,该文件执行时,其进程的euid值便会设成该文件所有者的uid。例如,执行文件/usr/bin/passwd的权限为- r-s--x--x,其s 位即为setID(SUID)位,而当任何用户在执行passwd 时其有效的用户识别码会被设成passwd 所有者的uid 值,即rootuid 值()。
  184. 返回值
  185. 返回有效的用户识别码。
  186. 范例
  187. main()
  188. {
  189. printf ("euid is %d \n",geteuid());
  190. }
  191. 执行
  192. euid /*当使用root身份执行范例程序时*/
  193.  
  194.  
  195. getgid(取得真实的组识别码)
  196. 相关函数
  197. getegidsetregidsetgid
  198. 表头文件
  199. #include<unistd.h>
  200. #include<sys/types.h>
  201. 定义函数
  202. gid_t getgid(void);
  203. 函数说明
  204. getgid()用来取得执行目前进程的组识别码。
  205. 返回值
  206. 返回组识别码
  207. 范例
  208. main()
  209. {
  210. printf(“gid is %d\n”,getgid());
  211. }
  212. 执行
  213. gid /*当使用root身份执行范例程序时*/
  214.  
  215.  
  216. getgrent(从组文件中取得账号的数据)
  217. 相关函数
  218. setgrentendgrent
  219. 表头文件
  220. #include<grp.h>
  221. #include <sys/types.h>
  222. 定义函数
  223. struct group *getgrent(void);
  224. 函数说明
  225. getgrent()用来从组文件(/etc/group)中读取一项组数据,该数据以group 结构返回。第一次调用时会取得第一项组数据,之后每调用一次就会返回下一项数据,直到已无任何数据时返回NULL
  226. struct group{
  227. char *gr_name; /*组名称*/
  228. char *gr_passwd; /* 组密码*/
  229. gid_t gr_gid; /*组识别码*/
  230. char **gr_mem; /*组成员账号*/
  231. }
  232. 返回值
  233. 返回group结构数据,如果返回NULL则表示已无数据,或有错误发生。
  234. 附加说明
  235. getgrent()在第一次调用时会打开组文件,读取数据完毕后可使用endgrent()来关闭该组文件。
  236. 错误代码
  237. ENOMEM 内存不足,无法配置group结构。
  238. 范例
  239. #include<grp.h>
  240. #include<sys/types.h>
  241. main()
  242. {
  243. struct group *data;
  244. int i;
  245. ){
  246. i=;
  247. printf(“%s:%s:%d:”,data->gr_name,data->gr_passwd,data->gr_gid);
  248. while(data->gr_mem[i])printf(“%s,”,data->gr_mem[i++]);
  249. printf(“\n”);
  250. }
  251. endgrent();
  252. }
  253. 执行
  254. root:x::root,
  255. bin:x::root,bin,daemon,
  256. daemon:x::root,bin,daemon,
  257. sys:x::root,bin,adm,
  258. adm:x::root,adm,daemon
  259. tty:x:
  260. disk:x::root
  261. lp:x::daemon,lp
  262. mem:x:
  263. kmem:x::
  264. wheel:x::root
  265. mail:x::mail
  266. news:x::news
  267. uucp:x::uucp
  268. man:x::
  269. games:x:
  270. gopher:x:
  271. dip:x:
  272. ftp:x:
  273. nobody:x:
  274.  
  275.  
  276. getgrgid(从组文件中取得指定gid 的数据)
  277. 相关函数
  278. fgetgrentgetgrentgetgrnam
  279. 表头文件
  280. #include<grp.h>
  281. #include<sys/types.h>
  282. 定义函数
  283. strcut group * getgrgid(gid_t gid);
  284. 函数说明
  285. getgrgid()用来依参数gid指定的组识别码逐一搜索组文件,找到时便将该组的数据以group结构返回。group结构请参考getgrent()。
  286. 返回值
  287. 返回group结构数据,如果返回NULL则表示已无数据,或有错误发生。
  288. 范例
  289. /* 取得gid=3的组数据*/
  290. #include<grp.h>
  291. #include<sys/types.h>
  292. main()
  293. {
  294. strcut group *data;
  295. ;
  296. data = getgrgid();
  297. printf(“%s:%s:%d:”,data->gr_name,data->gr_passwd,data->gr_gid);
  298. while(data->gr_mem[i])printf(“%s ,”,data->mem[i++]);
  299. printf(“\n”);
  300. }
  301. 执行
  302. sys:x::root,bin,adm
  303.  
  304.  
  305. getgrnam(从组文件中取得指定组的数据)
  306. 相关函数
  307. fgetgrentgetrentgetgruid
  308. 表头文件
  309. #include<grp.h>
  310. #include<sys/types.h>
  311. 定义函数
  312. strcut group * getgrnam(const char * name);
  313. 函数说明
  314. getgrnam()用来逐一搜索参数那么指定的组名称,找到时便将该组的数据以group结构返回。group 结构请参考getgrent()。
  315. 返回值
  316. 返回group结构数据,如果返回NULL则表示已无数据,或有错误发生。
  317. 范例
  318. /* 取得adm的组数据*/
  319. #include<grp.h>
  320. #include<sys/types.h>
  321. main()
  322. {
  323. strcut group * data;
  324. ;
  325. data = getgrnam(“adm”);
  326. printf(“%s:%s:%d:”,data->gr_name,data->gr_passwd,data->gr_gid);
  327. while(data->gr_mem[i])printf(“%s,”,data->gr_mem[i++]);
  328. printf(“\n”);
  329. }
  330. 执行
  331. adm:x::root,adm,daemon
  332.  
  333.  
  334. getgroups(取得组代码)
  335. 相关函数
  336. initgroupssetgroupgetgidsetgid
  337. 表头文件
  338. #include<unistd.h>
  339. #include<sys/types.h>
  340. 定义函数
  341. int getgroups(int size,gid_t list[]);
  342. 函数说明
  343. getgroup()用来取得目前用户所属的组代码。参数sizelist〔〕所能容纳的gid_t 数目。如果参数size 值为零,此函数仅会返回用户所属的组数。
  344. 返回值
  345. 返回组识别码,如有错误则返回-。
  346. 错误代码
  347. EFAULT 参数list数组地址不合法。EINVAL 参数size值不足以容纳所有的组。
  348. 范例
  349. #include<unistd.h>
  350. #include<sys/types.h>
  351. main()
  352. {
  353. gid_t list[];
  354. int x,i;
  355. x = getgroups(.list);
  356. getgroups(x,list);
  357. ;i<x;i++)
  358. printf(“%d:%d\n”,i,list[i]);
  359. }
  360. 执行
  361. :
  362. :
  363. :
  364. :
  365. :
  366. :
  367. :
  368.  
  369.  
  370. getpw(取得指定用户的密码文件数据)
  371. 相关函数
  372. getpwent
  373. 表头文件
  374. #include<pwd.h>
  375. #include<sys/types.h>
  376. 定义函数
  377. int getpw(uid_t uid,char *buf);
  378. 函数说明
  379. getpw()会从/etc/passwd中查找符合参数uid所指定的用户账号数据,找不到相关数据就返回-。所返回的buf字符串格式如下:账号:密码:用户识别码(uid):组识别码(gid):全名:根目录:shell
  380. 返回值
  381. 返回0表示成功,有错误发生时返回-。
  382. 附加说明
  383. . getpw()会有潜在的安全性问题,请尽量使用别的函数取代。
  384. . 使用shadow的系统已把用户密码抽出/etc/passwd,因此使用getpw()取得的密码将为“x”。
  385. 范例
  386. #include<pwd.h>
  387. #include<sys/types.h>
  388. main()
  389. {
  390. ];
  391. getpw(,buffer);
  392. printf(“%s\n”,buffer);
  393. }
  394. 执行
  395. root:x:::root:/root:/bin/bash
  396.  
  397.  
  398. getpwent(从密码文件中取得账号的数据)
  399. 相关函数
  400. getpwfgetpwentgetpwnamgetpwuidsetpwentendpwent
  401. 表头文件
  402. #include<pwd.h>
  403. #include<sys/types.h>
  404. 定义函数
  405. strcut passwd * getpwent(void);
  406. 函数说明
  407. getpwent()用来从密码文件(/etc/passwd)中读取一项用户数据,该用户的数据以passwd 结构返回。第一次调用时会取得第一位用户数据,之后每调用一次就会返回下一项数据,直到已无任何数据时返回NULL
  408. passwd 结构定义如下
  409. struct passwd{
  410. char * pw_name; /*用户账号*/
  411. char * pw_passwd; /*用户密码*/
  412. uid_t pw_uid; /*用户识别码*/
  413. gid_t pw_gid; /*组识别码*/
  414. char * pw_gecos; /*用户全名*/
  415. char * pw_dir; /*家目录*/
  416. char * pw_shell; /* 所使用的shell路径*/
  417. };
  418. 返回值
  419. 返回passwd 结构数据,如果返回NULL 则表示已无数据,或有错误发生。
  420. 附加说明
  421. getpwent()在第一次调用时会打开密码文件,读取数据完毕后可使用endpwent()来关闭该密码文件。错误代码ENOMEM 内存不足,无法配置passwd结构。
  422. 范例
  423. #include<pwd.h>
  424. #include<sys/types.h>
  425. main()
  426. {
  427. struct passwd *user;
  428. ){
  429. printf(“%s:%d:%d:%s:%s:%s\n”,user->pw_name,user->pw_uid,user->pw_gid,
  430. user->pw_gecos,user->pw_dir,user->pw_shell);
  431. }
  432. endpwent();
  433. }
  434. 执行
  435. root:::root:/root:/bin/bash
  436. bin:::bin:/bin:
  437. daemon:::daemon:/sbin:
  438. adm:::adm:/var/adm:
  439. lp:::lp:/var/spool/lpd:
  440. sync:::sync:/sbin:/bin/sync
  441. shutdown:::shutdown:/sbin:/sbin/shutdown
  442. halt:::halt:/sbin:/sbin/halt
  443. mail:::mail:/var/spool/mail:
  444. news:::news:var/spool/news
  445. uucp:::uucp:/var/spool/uucp:
  446. ::operator :/root:
  447. games:::games:/usr/games:
  448. gopher:::gopher:/usr/lib/gopher-data:
  449. ftp:::FTP User:/home/ftp:
  450. nobody:::Nobody:/:
  451. xfs:::X Font Server: /etc/Xll/fs:/bin/false
  452. gdm:::/home/gdm:/bin/bash
  453. kids::: : /home/kids:/bin/bash
  454.  
  455.  
  456. getpwnam(从密码文件中取得指定账号的数据)
  457. 相关函数
  458. getpwfgetpwentgetpwentgetpwuid
  459. 表头文件
  460. #include<pwd.h>
  461. #include<sys/types.h>
  462. 定义函数
  463. struct passwd * getpwnam(const char * name);
  464. 函数说明
  465. getpwnam()用来逐一搜索参数name 指定的账号名称,找到时便将该用户的数据以passwd结构返回。passwd结构请参考getpwent()。
  466. 返回值
  467. 返回passwd 结构数据,如果返回NULL 则表示已无数据,或有错误发生。
  468. 范例
  469. /*取得root账号的识别码和根目录*/
  470. #include<pwd.h>
  471. #include<sys/types.h>
  472. main()
  473. {
  474. struct passwd *user;
  475. user = getpwnam(“root”);
  476. printf(“name:%s\n”,user->pw_name);
  477. printf(“uid:%d\n”,user->pw_uid);
  478. printf(“home:%s\n”,user->pw_dir);
  479. }
  480. 执行
  481. name:root
  482. uid:
  483. home:/root
  484.  
  485.  
  486. getpwuid(从密码文件中取得指定uid 的数据)
  487. 相关函数
  488. getpwfgetpwentgetpwentgetpwnam
  489. 表头文件
  490. #include<pwd.h>
  491. #include<sys/types.h>
  492. 定义函数
  493. struct passwd * getpwuid(uid_t uid);
  494. 函数说明
  495. getpwuid()用来逐一搜索参数uid 指定的用户识别码,找到时便将该用户的数据以结构返回结构请参考将该用户的数据以passwd 结构返回。passwd 结构请参考getpwent()。
  496. 返回值
  497. 返回passwd 结构数据,如果返回NULL 则表示已无数据,或者有错误发生。
  498. 范例
  499. #include<pwd.h>
  500. #include<sys/types.h>
  501. main()
  502. {
  503. struct passwd *user;
  504. user= getpwuid();
  505. printf(“name:%s\n”,user->pw_name);
  506. printf(“uid:%d\n”,user->pw_uid);
  507. printf(“home:%s\n”,user->pw_dir);
  508. }
  509. 执行
  510. name:shutdown
  511. uid:
  512. home:/sbin
  513.  
  514.  
  515. getuid(取得真实的用户识别码)
  516. 相关函数
  517. geteuidsetreuidsetuid
  518. 表头文件
  519. #include<unistd.h>
  520. #include<sys/types.h>
  521. 定义函数
  522. uid_t getuid(void);
  523. 函数说明
  524. getuid()用来取得执行目前进程的用户识别码。
  525. 返回值
  526. 用户识别码
  527. 范例
  528. main()
  529. {
  530. printf(“uid is %d\n”,getuid());
  531. }
  532. 执行
  533. uid /*当使用root身份执行范例程序时*/
  534.  
  535.  
  536. getutent(从utmp 文件中取得账号登录数据)
  537. 相关函数
  538. getutentgetutidgetutlinesetutentendutentpututlineutmpname
  539. 表头文件
  540. #include<utmp.h>
  541. 定义函数
  542. struct utmp *getutent(void);
  543. 函数说明
  544. getutent()用来从utmp 文件(/var/run/utmp)中读取一项登录数据,该数据以utmp 结构返回。第一次调用时会取得第一位用户数据,之后每调用一次就会返回下一项数据,直到已无任何数据时返回NULL
  545. utmp结构定义如下
  546. struct utmp
  547. {
  548. short int ut_type; /*登录类型*/
  549. pid_t ut_pid; /*login进程的pid*/
  550. char ut_line[UT_LINESIZE];/*登录装置名,省略了“/dev/”*/
  551. ]; /* Inittab ID*/
  552. char ut_user[UT_NAMESIZE];/*登录账号*/
  553. char ut_host[UT_HOSTSIZE];/*登录账号的远程主机名称*/
  554. struxt exit_status ut_exit;/* 当类型为DEAD_PROCESS时进程的结
  555. 束状态*/
  556. long int ut_session; /*Sessioc ID*/
  557. struct timeval ut_tv; /*时间记录*/
  558. int32_t ut_addr_v6[]; /*远程主机的网络地址*/
  559. ]; /* 保留未使用*/
  560. };
  561. ut_type有以下几种类型:
  562. EMPTY 此为空的记录。
  563. RUN_LVL 记录系统runlevel的改变
  564. BOOT_TIME 记录系统开机时间
  565. NEW_TIME 记录系统时间改变后的时间
  566. OLD_TINE 记录当改变系统时间时的时间。
  567. INIT_PROCESS 记录一个由init衍生出来的进程。
  568. LOGIN_PROCESS 记录login进程。
  569. USER_PROCESS 记录一般进程。
  570. DEAD_PROCESS 记录一结束的进程。
  571. ACCOUNTING 目前尚未使用。
  572. exit_status结构定义
  573. struct exit_status
  574. {
  575. short int e_termination; /*进程结束状态*/
  576. short int e_exit; /*进程退出状态*/
  577. };
  578. timeval的结构定义请参考gettimeofday()。
  579. 相关常数定义如下:
  580. UT_LINESIZE
  581. UT_NAMESIZE
  582. UT_HOSTSIZE
  583. 返回值
  584. 返回utmp 结构数据,如果返回NULL 则表示已无数据,或有错误发生。
  585. 附加说明
  586. getutent()在第一次调用时会打开utmp 文件,读取数据完毕后可使用endutent()来关闭该utmp文件。
  587. 范例
  588. #include<utmp.h>
  589. main()
  590. {
  591. struct utmp *u;
  592. while((u=getutent())){
  593. if(u->ut_type = = USER_PROCESS)
  594. printf(“%d %s %s %s \n”,u->ut_type,u->ut_user,u->ut_line,u->ut_host);
  595. }
  596. endutent();
  597. }
  598. 执行
  599. /* 表示有三个root账号分别登录/dev/pts/0,/dev/pts/1,/dev/pts/2 */
  600. root pts/
  601. root pts/
  602. root pts/
  603.  
  604.  
  605. getutid(从utmp 文件中查找特定的记录)
  606. 相关函数
  607. getutentgetutline
  608. 表头文件
  609. #include<utmp.h>
  610. 定义函数
  611. strcut utmp *getutid(strcut utmp *ut);
  612. 函数说明
  613. getutid()用来从目前utmp 文件的读写位置逐一往后搜索参数ut指定的记录,如果ut->ut_type RUN_LVLBOOT_TIMENEW_TIMEOLD_TIME 其中之一则查找与ut->ut_type 相符的记录;若ut->ut_type INIT_PROCESSLOGIN_PROCESSUSER_PROCESSDEAD_PROCESS其中之一,则查找与ut->ut_id相符的记录。找到相符的记录便将该数据以utmp 结构返回。utmp结构请参考getutent()。
  614. 返回值
  615. 返回utmp 结构数据,如果返回NULL 则表示已无数据,或有错误发生。
  616. 范例
  617. #include<utmp.h>
  618. main()
  619. {
  620. struct utmp ut,*u;
  621. ut.ut_type=RUN_LVL;
  622. while((u= getutid(&ut))){
  623. printf(“%d %s %s %s\n”,u->ut_type,u->ut_user,u->ut_line,u->ut_host);
  624. }
  625. }
  626. 执行
  627. runlevel -
  628.  
  629.  
  630. getutline(从utmp 文件中查找特定的记录)
  631. 相关函数
  632. getutentgetutidpututline
  633. 表头文件
  634. #include<utmp.h>
  635. 定义函数
  636. struct utmp * getutline (struct utmp *ut);
  637. 函数说明
  638. getutline()用来从目前utmp文件的读写位置逐一往后搜索ut_typeUSER_PROCESS LOGIN_PROCESS 的记录,而且ut_line ut->ut_line 相符。找到相符的记录便将该数据以utmp 结构返回,utmp结构请参考getutent()。
  639. 返回值
  640. 返回utmp 结构数据,如果返回NULL 则表示已无数据,或有错误发生。
  641. 范例
  642. #include<utmp.h>
  643. main()
  644. {
  645. struct utmp ut,*u;
  646. strcpy (ut.ut_line,”pts/”);
  647. while ((u=getutline(&ut))){
  648. printf(“%d %s %s %s \n”,u->ut_type,u->ut_user,u->ut_line,u->ut_host);
  649. }
  650. }
  651. 执行
  652. root pts/
  653.  
  654.  
  655. initgroups(初始化组清单)
  656. 相关函数
  657. setgrentendgrent
  658. 表头文件
  659. #include<grp.h>
  660. #include<sys/types.h>
  661. 定义函数
  662. int initgroups(const char *user,gid_t group);
  663. 函数说明
  664. initgroups()用来从组文件(/etc/group)中读取一项组数据,若该组数据的成员中有参数user时,便将参数group组识别码加入到此数据中。
  665. 返回值
  666. 执行成功则返回0,失败则返回-,错误码存于errno
  667.  
  668.  
  669. pututline(将utmp 记录写入文件)
  670. 相关函数
  671. getutentgetutidgetutline
  672. 表头文件
  673. #include<utmp.h>
  674. 定义函数
  675. void pututline(struct utmp *ut);
  676. 函数说明
  677. pututline()用来将参数ututmp结构记录到utmp文件中。此函数会先用getutid()来取得正确的写入位置,如果没有找到相符的记录则会加入到utmp文件尾,utmp结构请参考getutent()。
  678. 返回值
  679.  
  680. 附加说明
  681. 需要有写入/var/run/utmp 的权限
  682. 范例
  683. #include<utmp.h>
  684. main()
  685. {
  686. struct utmp ut;
  687. ut.ut_type =USER_PROCESS;
  688. ut.ut_pid=getpid();
  689. strcpy(ut.ut_user,”kids”);
  690. strcpy(ut.ut_line,”pts/”);
  691. strcpy(ut.ut_host,”www.gnu.org”);
  692. pututline(&ut);
  693. }
  694. 执行
  695. /*执行范例后用指令who -l 观察*/
  696. root pts/ dec9 :
  697. kids pts/ dec12 :(www.gnu.org)
  698. root pts/ dec12 :
  699.  
  700.  
  701. seteuid(设置有效的用户识别码)
  702. 相关函数
  703. setuidsetreuidsetfsuid
  704. 表头文件
  705. #include<unistd.h>
  706. 定义函数
  707. int seteuid(uid_t euid);
  708. 函数说明
  709. seteuid()用来重新设置执行目前进程的有效用户识别码。在Linux下,seteuid(euid)相当于setreuid(-,euid)。
  710. 返回值
  711. 执行成功则返回0,失败则返回-,错误代码存于errno
  712. 附加说明
  713. 请参考setuid
  714.  
  715.  
  716. setfsgid(设置文件系统的组识别码)
  717. 相关函数
  718. setuidsetreuidseteuidsetfsuid
  719. 表头文件
  720. #include<unistd.h>
  721. 定义函数
  722. int setfsgid(uid_t fsgid);
  723. 函数说明
  724. setfsgid()用来重新设置目前进程的文件系统的组识别码。一般情况下,文件系统的组识别码(fsgid)与有效的组识别码(egid)是相同的。如果是超级用户调用此函数,参数fsgid 可以为任何值,否则参数fsgid必须为real/effective/saved的组识别码之一。
  725. 返回值
  726. 执行成功则返回0,失败则返回-,错误代码存于errno
  727. 附加说明
  728. 此函数为Linux特有。
  729. 错误代码
  730. EPERM 权限不够,无法完成设置。
  731.  
  732.  
  733. setfsuid(设置文件系统的用户识别码)
  734. 相关函数
  735. setuidsetreuidseteuidsetfsgid
  736. 表头文件
  737. #include<unistd.h>
  738. 定义函数
  739. int setfsuid(uid_t fsuid);
  740. 函数说明
  741. setfsuid()用来重新设置目前进程的文件系统的用户识别码。一般情况下,文件系统的用户识别码(fsuid)与有效的用户识别码(euid)是相 同的。如果是超级用户调用此函数,参数fsuid可以为任何值,否则参数fsuid必须为real/effective/saved的用户识别码之一。
  742. 返回值
  743. 执行成功则返回0,失败则返回-,错误代码存于errno
  744. 附加说明
  745. 此函数为Linux特有
  746. 错误代码
  747. EPERM 权限不够,无法完成设置。
  748.  
  749.  
  750. setgid(设置真实的组识别码)
  751. 相关函数
  752. getgidsetregidgetegidsetegid
  753. 表头文件
  754. #include<unistd.h>
  755. 定义函数
  756. int setgid(gid_t gid);
  757. 函数说明
  758. setgid()用来将目前进程的真实组识别码(real gid)设成参数gid值。如果是以超级用户身份执行此调用,则realeffectivesavedgid都会设成参数gid
  759. 返回值
  760. 设置成功则返回0,失败则返回-,错误代码存于errno中。
  761. 错误代码
  762. EPERM 并非以超级用户身份调用,而且参数gid 并非进程的effective gidsaved gid值之一。
  763.  
  764.  
  765. setgrent(从头读取组文件中的组数据)
  766. 相关函数
  767. getgrentendgrent
  768. 表头文件
  769. #include<grp.h>
  770. #include<sys/types.h>
  771. 定义函数
  772. void setgrent(void);
  773. 函数说明
  774. setgrent()用来将getgrent()的读写地址指回组文件开头。
  775. 返回值
  776.  
  777. 附加说明
  778. 请参考setpwent()。
  779.  
  780.  
  781. setgroups(设置组代码)
  782. 相关函数
  783. initgroupsgetgroupgetgidsetgid
  784. 表头文件
  785. #include<grp.h>
  786. 定义函数
  787. int setgroups(size_t size,const gid_t * list);
  788. 函数说明
  789. setgroups()用来将list 数组中所标明的组加入到目前进程的组设置中。参数sizelist()的gid_t数目,最大值为NGROUP()。
  790. 返回值
  791. 设置成功则返回0,如有错误则返回-。
  792. 错误代码
  793. EFAULT 参数list数组地址不合法。
  794. EPERM 权限不足,必须是root权限
  795. EINVAL 参数size值大于NGROUP()。
  796.  
  797.  
  798. setpwent(从头读取密码文件中的账号数据)
  799. 相关函数
  800. getpwentendpwent
  801. 表头文件
  802. #include<pwd.h>
  803. #include<sys/types.h>
  804. 定义函数
  805. void setpwent(void);
  806. 函数说明
  807. setpwent()用来将getpwent()的读写地址指回密码文件开头。
  808. 返回值
  809.  
  810. 范例
  811. #include<pwd.h>
  812. #include<sys/types.h>
  813. main()
  814. {
  815. struct passwd *user;
  816. int i;
  817. ;i<;i++){
  818. user=getpwent();
  819. printf(“%s :%d :%d :%s:%s:%s\n”,user->pw_name,user->pw_uid,user->pw_gid,
  820. user->pw_gecos,user->pw_dir,user->pw_shell);
  821. }
  822. setpwent();
  823. user=getpwent();
  824. printf(“%s :%d :%d :%s:%s:%s\n”,user->pw_name,user->pw_uid,user->pw_gid,
  825. user->pw_gecos,user->pw_dir,user->pw_shell);
  826. endpwent();
  827. }
  828. 执行
  829. root:::root:/root:/bin/bash
  830. bin:::bin:/bin
  831. daemon:::daemon:/sbin
  832. adm:::adm:/var/adm
  833. root:::root:/root:/bin/bash
  834.  
  835.  
  836. setregid(设置真实及有效的组识别码)
  837. 相关函数
  838. setgidsetegidsetfsgid
  839. 表头文件
  840. #include<unistd.h>
  841. 定义函数
  842. int setregid(gid_t rgid,gid_t egid);
  843. 函数说明
  844. setregid()用来将参数rgid设为目前进程的真实组识别码,将参数egid设置为目前进程的有效组识别码。如果参数rgidegid值为-,则对应的识别码不会改变。
  845. 返回值
  846. 执行成功则返回0,失败则返回-,错误代码存于errno
  847.  
  848.  
  849. setreuid(设置真实及有效的用户识别码)
  850. 相关函数
  851. setuidseteuidsetfsuid
  852. 表头文件
  853. #include<unistd.h>
  854. 定义函数
  855. int setreuid(uid_t ruid,uid_t euid);
  856. 函数说明
  857. setreuid()用来将参数ruid 设为目前进程的真实用户识别码,将参数euid 设置为目前进程的有效用户识别码。如果参数ruid euid值为-,则对应的识别码不会改变。
  858. 返回值
  859. 执行成功则返回0,失败则返回-,错误代码存于errno
  860. 附加说明
  861. 请参考setuid()。
  862.  
  863.  
  864. setuid(设置真实的用户识别码)
  865. 相关函数
  866. getuidsetreuidseteuidsetfsuid
  867. 表头文件
  868. #include<unistd.h>
  869. 定义函数
  870. int setuid(uid_t uid)
  871. 函数说明
  872. setuid()用来重新设置执行目前进程的用户识别码。不过,要让此函数有作用,其有效的用户识别码必须为0(root)。在Linux下,当root 使用setuid()来变换成其他用户识别码时,root权限会被抛弃,完全转换成该用户身份,也就是说,该进程往后将不再具有可setuid()的权 利,如果只是向暂时抛弃root 权限,稍后想重新取回权限,则必须使用seteuid()。
  873. 返回值
  874. 执行成功则返回0,失败则返回-,错误代码存于errno
  875. 附加说明
  876. 一般在编写具setuid root的程序时,为减少此类程序带来的系统安全风险,在使用完root权限后建议马上执行setuid(getuid());来抛弃root权限。此外,进程uideuid不一致时Linux系统将不会产生core dump
  877.  
  878.  
  879. setutent(从头读取utmp 文件中的登录数据)
  880. 相关函数
  881. getutentendutent
  882. 表头文件
  883. #include<utmp.h>
  884. 定义函数
  885. void setutent(void);
  886. 函数说明
  887. setutent()用来将getutent()的读写地址指回utmp文件开头。
  888. 附加说明
  889. 请参考setpwent()或setgrent()。
  890.  
  891.  
  892. utmpname(设置utmp 文件路径)
  893. 相关函数
  894. getutentgetutidgetutlinesetutentendutentpututline
  895. 表头文件
  896. #include<utmp.h>
  897. 定义函数
  898. void utmpname(const char * file);
  899. 函数说明
  900. utmpname()用来设置utmp文件的路径,以提供utmp相关函数的存取路径。如果没有使用utmpname()则默认utmp文件路径为/var/run/utmp
  901. 返回值

用户组篇endgrent getpw getuid的更多相关文章

  1. Linux -- 用户组篇

    Linux -- 用户与用户组 1.Linux 系统中有三种角色:所有者(用户),用户组与其他人,一张图可以说明用户与用户组的关系. 如图,某公司相当于一个用户组,该用户组下有A,B两个用户,用户拥有 ...

  2. Linux学习历程——Centos 7 账户管理命令(用户组篇)groupadd groupmod groupdel

    一.命令介绍 groupadd:创建用户组 groupmod:修改用户组属性 groupdel:删除用户组 ---------------------------------------------- ...

  3. linux常用C函数目录

    字符测试篇 isalnum isalpha isascii iscntrl isdigit isgraphis islower isprint isspace ispunct isupper isxd ...

  4. Linux -- 用户篇

    Linux -- 用户与用户组 1.Linux 系统中有三种角色:所有者(用户),用户组与其他人,一张图可以说明用户与用户组的关系. 如图,某公司相当于一个用户组,该用户组下有A,B两个用户,用户拥有 ...

  5. TGL站长关于常见问题的回复

    问题地址: http://www.thegrouplet.com/thread-112923-1-1.html 问题: 网站配有太多的模板是否影响网站加载速度 月光答复: wp不需要删除其他的模板,不 ...

  6. 搞清楚ourhdr.h是什么及运行第一个UNIX C程序

    好多人开始学:UNIX 环境高级编程这本书时:看到书里面说的头文件ourhdr.h而找不到她在哪里:而且无法开始继续学习:其实这个就是系统的内核标准头文件: 而她的位置在:/usr/include/u ...

  7. 推荐几篇关于EF的好文章

    文章作者 Julie Lerman 是 Microsoft MVP..NET 导师和顾问,住在佛蒙特州的山区.您可以在全球的用户组和会议中看到她对数据访问和其他 .NET 主题的演示.她的博客地址是 ...

  8. 【荐】如何规划 Nginx 网站目录的权限(用户,用户组,ssh,sftp)

    从上一篇文章:PHP网站(nginx.php-fpm.mysql) 用户权限解析,可以学习了解到,nginx 和 php-fpm 的用户是如何运作的. 有个工作场景: 1.公司的一台 CentOS 服 ...

  9. Python之路【第二十一篇】Django ORM详解

    ORM回顾 关系对象映射(Object Relational Mapping,简称ORM). django中遵循 Code Frist 的原则,即:根据代码中定义的类来自动生成数据库表. 对于ORM框 ...

随机推荐

  1. phpmyadmin新加用户登陆不了,测试解决方案。

    今天在给项目配置数据库管理平台时遇到一个问题,不论怎么添加mysql用户在登陆phpmyadmin时始终无法登陆,不管准不准许为空依然报出#1045 无法登陆服务器的错误,最后打开mysql库中use ...

  2. python处理汉字转拼音pypinyin

    主要是pypinyin 包,官网: http://pypinyin.readthedocs.io/zh_CN/master/index.html jieba包,主要是用来分词的,我之前的博文有介绍:h ...

  3. 【POJ】1704.Georgia and Bob

    题解 感觉挺神奇的 我们把石子从后往前相邻的两个两两配对,这样他们之间的空格就相当于一堆石子 而配对后左边棋子移动,右边棋子也一定可以跟上取 转化成简单的nim游戏,最后只要看转化出的这(N - 1) ...

  4. thinkphp3.2开启静态缓存与缓存规则设置

    网站的静态缓存对大访问量有很好的缓解作用,尤其对网站的大并发,可有效的缓解数据库的压力.在thinkphp中实现静态缓存很简单,thinkphp都已经封装好了直接调用即可. 静态缓存   首先设置 H ...

  5. JAVAEE——宜立方商城04:图片服务器FastDFS、富文本编辑器KindEditor、商品添加功能完成

    1. 学习计划 1.图片上传 a) 图片服务器FastDFS b) 图片上传功能实现 2.富文本编辑器的使用KindEditor 3.商品添加功能完成 2. 图片服务器的安装 1.存储空间可扩展. 2 ...

  6. Linux C函数库参考手册

    目录 第1章 字符测试函数 isalnum(测试字符是否为英文字母或数字) isalpha(测试字符是否为英文字母) isascii(测试字符是否为ascii码字符) isblank(测试字符是否为空 ...

  7. mysql 通过cmd 在命令行创建数据库

    一.连接MYSQL 格式: mysql -h主机地址 -u用户名 -p用户密码 1. 连接到本机上的MYSQL. 首先打开DOS窗口,然后进入目录mysql\bin,再键入命令mysql -u roo ...

  8. 排序算法之冒泡排序Java实现

    排序算法之冒泡排序 舞蹈演示排序: 冒泡排序: http://t.cn/hrf58M 希尔排序:http://t.cn/hrosvb  选择排序:http://t.cn/hros6e  插入排序:ht ...

  9. codevs 2596 售货员的难题

    2596 售货员的难题 时间限制: 1 s 空间限制: 32000 KB 题目等级 : 钻石 Diamond 题目描述 Description 某乡有n个村庄(1<n<=15),有一个售货 ...

  10. 【贪心】【堆】Gym - 101775B - Scapegoat

    题意:有n个事件,每个事件有一个严重程度,m个人(m>=n),你要让m个人去背锅,每个人只能背一个事件的锅,但是一个事件可以由很多人背.让你使得这m个人所承受的严重程度的方差最小化. 考虑一开始 ...