用户组篇endgrent getpw getuid
- endgrent(关闭组文件)
- 相关函数
- getgrent,setgrent
- 表头文件
- #include<grp.h>
- #include<sys/types.h>
- 定义函数
- void endgrent(void);
- 函数说明
- endgrent()用来关闭由getgrent()所打开的密码文件。
- 返回值
- 附加说明
- 范例
- 请参考getgrent()与setgrent()。
- endpwent(关闭密码文件)
- 相关函数
- getpwent,setpwent
- 表头文件
- #include<pwd.h>
- #include<sys/types.h>
- 定义函数
- void endpwent(void);
- 函数说明
- endpwent()用来关闭由getpwent()所打开的密码文件。
- 返回值
- 附加说明
- 范例
- 请参考getpwent()与setpwent()。
- endutent(关闭utmp 文件)
- 相关函数
- getutent,setutent
- 表头文件
- #include<utmp.h>
- 定义函数
- void endutent(void);
- 函数说明
- endutent()用来关闭由getutent所打开的utmp文件。
- 返回值
- 附加说明
- 范例
- 请参考getutent()。
- fgetgrent(从指定的文件来读取组格式)
- 相关函数
- fgetpwent
- 表头文件
- #include<grp.h>
- #include<stdio.h>
- #include<sys/types.h>
- 定义函数
- struct group * getgrent(FILE * stream);
- 函数说明
- fgetgrent()会从参数stream指定的文件读取一行数据,然后以group结构将该数据返回。参数stream所指定的文件必须和、etc/group相同的格式。group结构定义请参考getgrent()。
- 返回值
- 返回group结构数据,如果返回NULL则表示已无数据,或有错误发生。
- 范例
- #include <grp.h>
- #include<sys/types.h>
- #include<stdio.h>
- main()
- {
- struct group *data;
- FILE *stream;
- int i;
- stream = fopen("/etc/group", "r");
- ){
- i=;
- printf("%s :%s:%d :", data->gr_name,data->gr_passwd,data->gr_gid);
- while (data->gr_mem[i])printf("%s,",data->gr_mem[i++]);
- printf("\n");
- }
- fclose(stream);
- }
- 执行
- root:x::root,
- bin:x::root,bin,daemon
- daemon:x::root,bin,daemon
- sys:x::root,bin,adm
- adm:x::root,adm,daemon
- tty:x:
- disk:x::root
- lp:x::daemon,lp
- mem:x:
- kmem:x:
- wheel:x::root
- mail:x::mail
- news:x::news
- uucp:x::uucp
- man:x:
- games:x:
- gopher:x:
- dip:x::
- ftp:x:
- nobody:x::
- fgetpwent(从指定的文件来读取密码格式)
- 相关函数
- fgetgrent
- 表头文件
- #include<pwd.h>
- #include<stdio.h>
- #include<sys/types.h>
- 定义函数
- struct passwd * fgetpwent(FILE *stream);
- 函数说明
- fgetpwent()会从参数stream指定的文件读取一行数据,然后以passwd结构将该数据返回。参数stream所指定的文件必须和/etc/passwd相同的格式。passwd结构定义请参考getpwent()。
- 返回值
- 返回passwd结构数据,如果返回NULL则表示已无数据,或有错误发生。
- 范例
- #include<pwd.h>
- #include<sys/types.h>
- main()
- {
- struct passwd *user;
- FILE *stream;
- stream = fopen("/etc/passwd", "r");
- ){
- 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);
- }
- }
- 执行
- root:::root:/root:/bin/bash
- bin:::bin:/bin:
- daemon:::daemon:/sbin:
- adm:::adm:/var/adm:
- lp:::lp:/var/spool/lpd:
- sync:::sync:/sbin:/bin/sync
- shutdown:::shutdown:/sbin:/sbin/shutdown
- halt:::halt:/sbin:/sbin/halt
- mail:::mail:/var/spool/mail:
- news:::news:var/spool/news
- uucp:::uucp:/var/spool/uucp:
- ::operator :/root:
- games:::games:/usr/games:
- gopher:::gopher:/usr/lib/gopher-data:
- ftp:::FTP User:/home/ftp:
- nobody:::Nobody:/:
- xfs:::X Font Server: /etc/Xll/fs:/bin/false
- gdm:::/home/gdm:/bin/bash
- kids::: : /home/kids:/bin/bash
- getegid(取得有效的组识别码)
- 相关函数
- getgid,setgid,setregid
- 表头文件
- #include<unistd.h>
- #include<sys/types.h>
- 定义函数
- gid_t getegid(void);
- 函数说明
- getegid()用来取得执行目前进程有效组识别码。有效的组识别码用来决定进程执行时组的权限。返回值返回有效的组识别码。
- 范例
- main()
- {
- printf("egid is %d\n",getegid());
- }
- 执行
- egid /*当使用root身份执行范例程序时*/
- geteuid(取得有效的用户识别码)
- 相关函数
- getuid,setreuid,setuid
- 表头文件
- #include<unistd.h>
- #include<sys/types.h>
- 定义函数
- uid_t geteuid(void)
- 函数说明
- geteuid()用来取得执行目前进程有效的用户识别码。有效的用户识别码用来决定进程执行的权限,借由此改变此值,进程可以获得额外的权限。倘若执行 文件的setID位已被设置,该文件执行时,其进程的euid值便会设成该文件所有者的uid。例如,执行文件/usr/bin/passwd的权限为- r-s--x--x,其s 位即为setID(SUID)位,而当任何用户在执行passwd 时其有效的用户识别码会被设成passwd 所有者的uid 值,即root的uid 值()。
- 返回值
- 返回有效的用户识别码。
- 范例
- main()
- {
- printf ("euid is %d \n",geteuid());
- }
- 执行
- euid /*当使用root身份执行范例程序时*/
- getgid(取得真实的组识别码)
- 相关函数
- getegid,setregid,setgid
- 表头文件
- #include<unistd.h>
- #include<sys/types.h>
- 定义函数
- gid_t getgid(void);
- 函数说明
- getgid()用来取得执行目前进程的组识别码。
- 返回值
- 返回组识别码
- 范例
- main()
- {
- printf(“gid is %d\n”,getgid());
- }
- 执行
- gid /*当使用root身份执行范例程序时*/
- getgrent(从组文件中取得账号的数据)
- 相关函数
- setgrent,endgrent
- 表头文件
- #include<grp.h>
- #include <sys/types.h>
- 定义函数
- struct group *getgrent(void);
- 函数说明
- getgrent()用来从组文件(/etc/group)中读取一项组数据,该数据以group 结构返回。第一次调用时会取得第一项组数据,之后每调用一次就会返回下一项数据,直到已无任何数据时返回NULL。
- struct group{
- char *gr_name; /*组名称*/
- char *gr_passwd; /* 组密码*/
- gid_t gr_gid; /*组识别码*/
- char **gr_mem; /*组成员账号*/
- }
- 返回值
- 返回group结构数据,如果返回NULL则表示已无数据,或有错误发生。
- 附加说明
- getgrent()在第一次调用时会打开组文件,读取数据完毕后可使用endgrent()来关闭该组文件。
- 错误代码
- ENOMEM 内存不足,无法配置group结构。
- 范例
- #include<grp.h>
- #include<sys/types.h>
- main()
- {
- struct group *data;
- int i;
- ){
- i=;
- printf(“%s:%s:%d:”,data->gr_name,data->gr_passwd,data->gr_gid);
- while(data->gr_mem[i])printf(“%s,”,data->gr_mem[i++]);
- printf(“\n”);
- }
- endgrent();
- }
- 执行
- root:x::root,
- bin:x::root,bin,daemon,
- daemon:x::root,bin,daemon,
- sys:x::root,bin,adm,
- adm:x::root,adm,daemon
- tty:x:
- disk:x::root
- lp:x::daemon,lp
- mem:x:
- kmem:x::
- wheel:x::root
- mail:x::mail
- news:x::news
- uucp:x::uucp
- man:x::
- games:x:
- gopher:x:
- dip:x:
- ftp:x:
- nobody:x:
- getgrgid(从组文件中取得指定gid 的数据)
- 相关函数
- fgetgrent,getgrent,getgrnam
- 表头文件
- #include<grp.h>
- #include<sys/types.h>
- 定义函数
- strcut group * getgrgid(gid_t gid);
- 函数说明
- getgrgid()用来依参数gid指定的组识别码逐一搜索组文件,找到时便将该组的数据以group结构返回。group结构请参考getgrent()。
- 返回值
- 返回group结构数据,如果返回NULL则表示已无数据,或有错误发生。
- 范例
- /* 取得gid=3的组数据*/
- #include<grp.h>
- #include<sys/types.h>
- main()
- {
- strcut group *data;
- ;
- data = getgrgid();
- printf(“%s:%s:%d:”,data->gr_name,data->gr_passwd,data->gr_gid);
- while(data->gr_mem[i])printf(“%s ,”,data->mem[i++]);
- printf(“\n”);
- }
- 执行
- sys:x::root,bin,adm
- getgrnam(从组文件中取得指定组的数据)
- 相关函数
- fgetgrent,getrent,getgruid
- 表头文件
- #include<grp.h>
- #include<sys/types.h>
- 定义函数
- strcut group * getgrnam(const char * name);
- 函数说明
- getgrnam()用来逐一搜索参数那么指定的组名称,找到时便将该组的数据以group结构返回。group 结构请参考getgrent()。
- 返回值
- 返回group结构数据,如果返回NULL则表示已无数据,或有错误发生。
- 范例
- /* 取得adm的组数据*/
- #include<grp.h>
- #include<sys/types.h>
- main()
- {
- strcut group * data;
- ;
- data = getgrnam(“adm”);
- printf(“%s:%s:%d:”,data->gr_name,data->gr_passwd,data->gr_gid);
- while(data->gr_mem[i])printf(“%s,”,data->gr_mem[i++]);
- printf(“\n”);
- }
- 执行
- adm:x::root,adm,daemon
- getgroups(取得组代码)
- 相关函数
- initgroups,setgroup,getgid,setgid
- 表头文件
- #include<unistd.h>
- #include<sys/types.h>
- 定义函数
- int getgroups(int size,gid_t list[]);
- 函数说明
- getgroup()用来取得目前用户所属的组代码。参数size为list〔〕所能容纳的gid_t 数目。如果参数size 值为零,此函数仅会返回用户所属的组数。
- 返回值
- 返回组识别码,如有错误则返回-。
- 错误代码
- EFAULT 参数list数组地址不合法。EINVAL 参数size值不足以容纳所有的组。
- 范例
- #include<unistd.h>
- #include<sys/types.h>
- main()
- {
- gid_t list[];
- int x,i;
- x = getgroups(.list);
- getgroups(x,list);
- ;i<x;i++)
- printf(“%d:%d\n”,i,list[i]);
- }
- 执行
- :
- :
- :
- :
- :
- :
- :
- getpw(取得指定用户的密码文件数据)
- 相关函数
- getpwent
- 表头文件
- #include<pwd.h>
- #include<sys/types.h>
- 定义函数
- int getpw(uid_t uid,char *buf);
- 函数说明
- getpw()会从/etc/passwd中查找符合参数uid所指定的用户账号数据,找不到相关数据就返回-。所返回的buf字符串格式如下:账号:密码:用户识别码(uid):组识别码(gid):全名:根目录:shell
- 返回值
- 返回0表示成功,有错误发生时返回-。
- 附加说明
- . getpw()会有潜在的安全性问题,请尽量使用别的函数取代。
- . 使用shadow的系统已把用户密码抽出/etc/passwd,因此使用getpw()取得的密码将为“x”。
- 范例
- #include<pwd.h>
- #include<sys/types.h>
- main()
- {
- ];
- getpw(,buffer);
- printf(“%s\n”,buffer);
- }
- 执行
- root:x:::root:/root:/bin/bash
- getpwent(从密码文件中取得账号的数据)
- 相关函数
- getpw,fgetpwent,getpwnam,getpwuid,setpwent,endpwent
- 表头文件
- #include<pwd.h>
- #include<sys/types.h>
- 定义函数
- strcut passwd * getpwent(void);
- 函数说明
- getpwent()用来从密码文件(/etc/passwd)中读取一项用户数据,该用户的数据以passwd 结构返回。第一次调用时会取得第一位用户数据,之后每调用一次就会返回下一项数据,直到已无任何数据时返回NULL。
- passwd 结构定义如下
- struct passwd{
- char * pw_name; /*用户账号*/
- char * pw_passwd; /*用户密码*/
- uid_t pw_uid; /*用户识别码*/
- gid_t pw_gid; /*组识别码*/
- char * pw_gecos; /*用户全名*/
- char * pw_dir; /*家目录*/
- char * pw_shell; /* 所使用的shell路径*/
- };
- 返回值
- 返回passwd 结构数据,如果返回NULL 则表示已无数据,或有错误发生。
- 附加说明
- getpwent()在第一次调用时会打开密码文件,读取数据完毕后可使用endpwent()来关闭该密码文件。错误代码ENOMEM 内存不足,无法配置passwd结构。
- 范例
- #include<pwd.h>
- #include<sys/types.h>
- main()
- {
- struct passwd *user;
- ){
- 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);
- }
- endpwent();
- }
- 执行
- root:::root:/root:/bin/bash
- bin:::bin:/bin:
- daemon:::daemon:/sbin:
- adm:::adm:/var/adm:
- lp:::lp:/var/spool/lpd:
- sync:::sync:/sbin:/bin/sync
- shutdown:::shutdown:/sbin:/sbin/shutdown
- halt:::halt:/sbin:/sbin/halt
- mail:::mail:/var/spool/mail:
- news:::news:var/spool/news
- uucp:::uucp:/var/spool/uucp:
- ::operator :/root:
- games:::games:/usr/games:
- gopher:::gopher:/usr/lib/gopher-data:
- ftp:::FTP User:/home/ftp:
- nobody:::Nobody:/:
- xfs:::X Font Server: /etc/Xll/fs:/bin/false
- gdm:::/home/gdm:/bin/bash
- kids::: : /home/kids:/bin/bash
- getpwnam(从密码文件中取得指定账号的数据)
- 相关函数
- getpw,fgetpwent,getpwent,getpwuid
- 表头文件
- #include<pwd.h>
- #include<sys/types.h>
- 定义函数
- struct passwd * getpwnam(const char * name);
- 函数说明
- getpwnam()用来逐一搜索参数name 指定的账号名称,找到时便将该用户的数据以passwd结构返回。passwd结构请参考getpwent()。
- 返回值
- 返回passwd 结构数据,如果返回NULL 则表示已无数据,或有错误发生。
- 范例
- /*取得root账号的识别码和根目录*/
- #include<pwd.h>
- #include<sys/types.h>
- main()
- {
- struct passwd *user;
- user = getpwnam(“root”);
- printf(“name:%s\n”,user->pw_name);
- printf(“uid:%d\n”,user->pw_uid);
- printf(“home:%s\n”,user->pw_dir);
- }
- 执行
- name:root
- uid:
- home:/root
- getpwuid(从密码文件中取得指定uid 的数据)
- 相关函数
- getpw,fgetpwent,getpwent,getpwnam
- 表头文件
- #include<pwd.h>
- #include<sys/types.h>
- 定义函数
- struct passwd * getpwuid(uid_t uid);
- 函数说明
- getpwuid()用来逐一搜索参数uid 指定的用户识别码,找到时便将该用户的数据以结构返回结构请参考将该用户的数据以passwd 结构返回。passwd 结构请参考getpwent()。
- 返回值
- 返回passwd 结构数据,如果返回NULL 则表示已无数据,或者有错误发生。
- 范例
- #include<pwd.h>
- #include<sys/types.h>
- main()
- {
- struct passwd *user;
- user= getpwuid();
- printf(“name:%s\n”,user->pw_name);
- printf(“uid:%d\n”,user->pw_uid);
- printf(“home:%s\n”,user->pw_dir);
- }
- 执行
- name:shutdown
- uid:
- home:/sbin
- getuid(取得真实的用户识别码)
- 相关函数
- geteuid,setreuid,setuid
- 表头文件
- #include<unistd.h>
- #include<sys/types.h>
- 定义函数
- uid_t getuid(void);
- 函数说明
- getuid()用来取得执行目前进程的用户识别码。
- 返回值
- 用户识别码
- 范例
- main()
- {
- printf(“uid is %d\n”,getuid());
- }
- 执行
- uid /*当使用root身份执行范例程序时*/
- getutent(从utmp 文件中取得账号登录数据)
- 相关函数
- getutent,getutid,getutline,setutent,endutent,pututline,utmpname
- 表头文件
- #include<utmp.h>
- 定义函数
- struct utmp *getutent(void);
- 函数说明
- getutent()用来从utmp 文件(/var/run/utmp)中读取一项登录数据,该数据以utmp 结构返回。第一次调用时会取得第一位用户数据,之后每调用一次就会返回下一项数据,直到已无任何数据时返回NULL。
- utmp结构定义如下
- struct utmp
- {
- short int ut_type; /*登录类型*/
- pid_t ut_pid; /*login进程的pid*/
- char ut_line[UT_LINESIZE];/*登录装置名,省略了“/dev/”*/
- ]; /* Inittab ID*/
- char ut_user[UT_NAMESIZE];/*登录账号*/
- char ut_host[UT_HOSTSIZE];/*登录账号的远程主机名称*/
- struxt exit_status ut_exit;/* 当类型为DEAD_PROCESS时进程的结
- 束状态*/
- long int ut_session; /*Sessioc ID*/
- struct timeval ut_tv; /*时间记录*/
- int32_t ut_addr_v6[]; /*远程主机的网络地址*/
- ]; /* 保留未使用*/
- };
- ut_type有以下几种类型:
- EMPTY 此为空的记录。
- RUN_LVL 记录系统run-level的改变
- BOOT_TIME 记录系统开机时间
- NEW_TIME 记录系统时间改变后的时间
- OLD_TINE 记录当改变系统时间时的时间。
- INIT_PROCESS 记录一个由init衍生出来的进程。
- LOGIN_PROCESS 记录login进程。
- USER_PROCESS 记录一般进程。
- DEAD_PROCESS 记录一结束的进程。
- ACCOUNTING 目前尚未使用。
- exit_status结构定义
- struct exit_status
- {
- short int e_termination; /*进程结束状态*/
- short int e_exit; /*进程退出状态*/
- };
- timeval的结构定义请参考gettimeofday()。
- 相关常数定义如下:
- UT_LINESIZE
- UT_NAMESIZE
- UT_HOSTSIZE
- 返回值
- 返回utmp 结构数据,如果返回NULL 则表示已无数据,或有错误发生。
- 附加说明
- getutent()在第一次调用时会打开utmp 文件,读取数据完毕后可使用endutent()来关闭该utmp文件。
- 范例
- #include<utmp.h>
- main()
- {
- struct utmp *u;
- while((u=getutent())){
- if(u->ut_type = = USER_PROCESS)
- printf(“%d %s %s %s \n”,u->ut_type,u->ut_user,u->ut_line,u->ut_host);
- }
- endutent();
- }
- 执行
- /* 表示有三个root账号分别登录/dev/pts/0,/dev/pts/1,/dev/pts/2 */
- root pts/
- root pts/
- root pts/
- getutid(从utmp 文件中查找特定的记录)
- 相关函数
- getutent,getutline
- 表头文件
- #include<utmp.h>
- 定义函数
- strcut utmp *getutid(strcut utmp *ut);
- 函数说明
- getutid()用来从目前utmp 文件的读写位置逐一往后搜索参数ut指定的记录,如果ut->ut_type 为RUN_LVL,BOOT_TIME,NEW_TIME,OLD_TIME 其中之一则查找与ut->ut_type 相符的记录;若ut->ut_type 为INIT_PROCESS,LOGIN_PROCESS,USER_PROCESS或DEAD_PROCESS其中之一,则查找与ut->ut_id相符的记录。找到相符的记录便将该数据以utmp 结构返回。utmp结构请参考getutent()。
- 返回值
- 返回utmp 结构数据,如果返回NULL 则表示已无数据,或有错误发生。
- 范例
- #include<utmp.h>
- main()
- {
- struct utmp ut,*u;
- ut.ut_type=RUN_LVL;
- while((u= getutid(&ut))){
- printf(“%d %s %s %s\n”,u->ut_type,u->ut_user,u->ut_line,u->ut_host);
- }
- }
- 执行
- runlevel -
- getutline(从utmp 文件中查找特定的记录)
- 相关函数
- getutent,getutid,pututline
- 表头文件
- #include<utmp.h>
- 定义函数
- struct utmp * getutline (struct utmp *ut);
- 函数说明
- getutline()用来从目前utmp文件的读写位置逐一往后搜索ut_type为USER_PROCESS 或LOGIN_PROCESS 的记录,而且ut_line 和ut->ut_line 相符。找到相符的记录便将该数据以utmp 结构返回,utmp结构请参考getutent()。
- 返回值
- 返回utmp 结构数据,如果返回NULL 则表示已无数据,或有错误发生。
- 范例
- #include<utmp.h>
- main()
- {
- struct utmp ut,*u;
- strcpy (ut.ut_line,”pts/”);
- while ((u=getutline(&ut))){
- printf(“%d %s %s %s \n”,u->ut_type,u->ut_user,u->ut_line,u->ut_host);
- }
- }
- 执行
- root pts/
- initgroups(初始化组清单)
- 相关函数
- setgrent,endgrent
- 表头文件
- #include<grp.h>
- #include<sys/types.h>
- 定义函数
- int initgroups(const char *user,gid_t group);
- 函数说明
- initgroups()用来从组文件(/etc/group)中读取一项组数据,若该组数据的成员中有参数user时,便将参数group组识别码加入到此数据中。
- 返回值
- 执行成功则返回0,失败则返回-,错误码存于errno。
- pututline(将utmp 记录写入文件)
- 相关函数
- getutent,getutid,getutline
- 表头文件
- #include<utmp.h>
- 定义函数
- void pututline(struct utmp *ut);
- 函数说明
- pututline()用来将参数ut的utmp结构记录到utmp文件中。此函数会先用getutid()来取得正确的写入位置,如果没有找到相符的记录则会加入到utmp文件尾,utmp结构请参考getutent()。
- 返回值
- 附加说明
- 需要有写入/var/run/utmp 的权限
- 范例
- #include<utmp.h>
- main()
- {
- struct utmp ut;
- ut.ut_type =USER_PROCESS;
- ut.ut_pid=getpid();
- strcpy(ut.ut_user,”kids”);
- strcpy(ut.ut_line,”pts/”);
- strcpy(ut.ut_host,”www.gnu.org”);
- pututline(&ut);
- }
- 执行
- /*执行范例后用指令who -l 观察*/
- root pts/ dec9 :
- kids pts/ dec12 :(www.gnu.org)
- root pts/ dec12 :
- seteuid(设置有效的用户识别码)
- 相关函数
- setuid,setreuid,setfsuid
- 表头文件
- #include<unistd.h>
- 定义函数
- int seteuid(uid_t euid);
- 函数说明
- seteuid()用来重新设置执行目前进程的有效用户识别码。在Linux下,seteuid(euid)相当于setreuid(-,euid)。
- 返回值
- 执行成功则返回0,失败则返回-,错误代码存于errno
- 附加说明
- 请参考setuid
- setfsgid(设置文件系统的组识别码)
- 相关函数
- setuid,setreuid,seteuid,setfsuid
- 表头文件
- #include<unistd.h>
- 定义函数
- int setfsgid(uid_t fsgid);
- 函数说明
- setfsgid()用来重新设置目前进程的文件系统的组识别码。一般情况下,文件系统的组识别码(fsgid)与有效的组识别码(egid)是相同的。如果是超级用户调用此函数,参数fsgid 可以为任何值,否则参数fsgid必须为real/effective/saved的组识别码之一。
- 返回值
- 执行成功则返回0,失败则返回-,错误代码存于errno。
- 附加说明
- 此函数为Linux特有。
- 错误代码
- EPERM 权限不够,无法完成设置。
- setfsuid(设置文件系统的用户识别码)
- 相关函数
- setuid,setreuid,seteuid,setfsgid
- 表头文件
- #include<unistd.h>
- 定义函数
- int setfsuid(uid_t fsuid);
- 函数说明
- setfsuid()用来重新设置目前进程的文件系统的用户识别码。一般情况下,文件系统的用户识别码(fsuid)与有效的用户识别码(euid)是相 同的。如果是超级用户调用此函数,参数fsuid可以为任何值,否则参数fsuid必须为real/effective/saved的用户识别码之一。
- 返回值
- 执行成功则返回0,失败则返回-,错误代码存于errno
- 附加说明
- 此函数为Linux特有
- 错误代码
- EPERM 权限不够,无法完成设置。
- setgid(设置真实的组识别码)
- 相关函数
- getgid,setregid,getegid,setegid
- 表头文件
- #include<unistd.h>
- 定义函数
- int setgid(gid_t gid);
- 函数说明
- setgid()用来将目前进程的真实组识别码(real gid)设成参数gid值。如果是以超级用户身份执行此调用,则real、effective与savedgid都会设成参数gid。
- 返回值
- 设置成功则返回0,失败则返回-,错误代码存于errno中。
- 错误代码
- EPERM 并非以超级用户身份调用,而且参数gid 并非进程的effective gid或saved gid值之一。
- setgrent(从头读取组文件中的组数据)
- 相关函数
- getgrent,endgrent
- 表头文件
- #include<grp.h>
- #include<sys/types.h>
- 定义函数
- void setgrent(void);
- 函数说明
- setgrent()用来将getgrent()的读写地址指回组文件开头。
- 返回值
- 附加说明
- 请参考setpwent()。
- setgroups(设置组代码)
- 相关函数
- initgroups,getgroup,getgid,setgid
- 表头文件
- #include<grp.h>
- 定义函数
- int setgroups(size_t size,const gid_t * list);
- 函数说明
- setgroups()用来将list 数组中所标明的组加入到目前进程的组设置中。参数size为list()的gid_t数目,最大值为NGROUP()。
- 返回值
- 设置成功则返回0,如有错误则返回-。
- 错误代码
- EFAULT 参数list数组地址不合法。
- EPERM 权限不足,必须是root权限
- EINVAL 参数size值大于NGROUP()。
- setpwent(从头读取密码文件中的账号数据)
- 相关函数
- getpwent,endpwent
- 表头文件
- #include<pwd.h>
- #include<sys/types.h>
- 定义函数
- void setpwent(void);
- 函数说明
- setpwent()用来将getpwent()的读写地址指回密码文件开头。
- 返回值
- 范例
- #include<pwd.h>
- #include<sys/types.h>
- main()
- {
- struct passwd *user;
- int i;
- ;i<;i++){
- user=getpwent();
- 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);
- }
- setpwent();
- user=getpwent();
- 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);
- endpwent();
- }
- 执行
- root:::root:/root:/bin/bash
- bin:::bin:/bin
- daemon:::daemon:/sbin
- adm:::adm:/var/adm
- root:::root:/root:/bin/bash
- setregid(设置真实及有效的组识别码)
- 相关函数
- setgid,setegid,setfsgid
- 表头文件
- #include<unistd.h>
- 定义函数
- int setregid(gid_t rgid,gid_t egid);
- 函数说明
- setregid()用来将参数rgid设为目前进程的真实组识别码,将参数egid设置为目前进程的有效组识别码。如果参数rgid或egid值为-,则对应的识别码不会改变。
- 返回值
- 执行成功则返回0,失败则返回-,错误代码存于errno。
- setreuid(设置真实及有效的用户识别码)
- 相关函数
- setuid,seteuid,setfsuid
- 表头文件
- #include<unistd.h>
- 定义函数
- int setreuid(uid_t ruid,uid_t euid);
- 函数说明
- setreuid()用来将参数ruid 设为目前进程的真实用户识别码,将参数euid 设置为目前进程的有效用户识别码。如果参数ruid 或euid值为-,则对应的识别码不会改变。
- 返回值
- 执行成功则返回0,失败则返回-,错误代码存于errno。
- 附加说明
- 请参考setuid()。
- setuid(设置真实的用户识别码)
- 相关函数
- getuid,setreuid,seteuid,setfsuid
- 表头文件
- #include<unistd.h>
- 定义函数
- int setuid(uid_t uid)
- 函数说明
- setuid()用来重新设置执行目前进程的用户识别码。不过,要让此函数有作用,其有效的用户识别码必须为0(root)。在Linux下,当root 使用setuid()来变换成其他用户识别码时,root权限会被抛弃,完全转换成该用户身份,也就是说,该进程往后将不再具有可setuid()的权 利,如果只是向暂时抛弃root 权限,稍后想重新取回权限,则必须使用seteuid()。
- 返回值
- 执行成功则返回0,失败则返回-,错误代码存于errno。
- 附加说明
- 一般在编写具setuid root的程序时,为减少此类程序带来的系统安全风险,在使用完root权限后建议马上执行setuid(getuid());来抛弃root权限。此外,进程uid和euid不一致时Linux系统将不会产生core dump。
- setutent(从头读取utmp 文件中的登录数据)
- 相关函数
- getutent,endutent
- 表头文件
- #include<utmp.h>
- 定义函数
- void setutent(void);
- 函数说明
- setutent()用来将getutent()的读写地址指回utmp文件开头。
- 附加说明
- 请参考setpwent()或setgrent()。
- utmpname(设置utmp 文件路径)
- 相关函数
- getutent,getutid,getutline,setutent,endutent,pututline
- 表头文件
- #include<utmp.h>
- 定义函数
- void utmpname(const char * file);
- 函数说明
- utmpname()用来设置utmp文件的路径,以提供utmp相关函数的存取路径。如果没有使用utmpname()则默认utmp文件路径为/var/run/utmp。
- 返回值
用户组篇endgrent getpw getuid的更多相关文章
- Linux -- 用户组篇
Linux -- 用户与用户组 1.Linux 系统中有三种角色:所有者(用户),用户组与其他人,一张图可以说明用户与用户组的关系. 如图,某公司相当于一个用户组,该用户组下有A,B两个用户,用户拥有 ...
- Linux学习历程——Centos 7 账户管理命令(用户组篇)groupadd groupmod groupdel
一.命令介绍 groupadd:创建用户组 groupmod:修改用户组属性 groupdel:删除用户组 ---------------------------------------------- ...
- linux常用C函数目录
字符测试篇 isalnum isalpha isascii iscntrl isdigit isgraphis islower isprint isspace ispunct isupper isxd ...
- Linux -- 用户篇
Linux -- 用户与用户组 1.Linux 系统中有三种角色:所有者(用户),用户组与其他人,一张图可以说明用户与用户组的关系. 如图,某公司相当于一个用户组,该用户组下有A,B两个用户,用户拥有 ...
- TGL站长关于常见问题的回复
问题地址: http://www.thegrouplet.com/thread-112923-1-1.html 问题: 网站配有太多的模板是否影响网站加载速度 月光答复: wp不需要删除其他的模板,不 ...
- 搞清楚ourhdr.h是什么及运行第一个UNIX C程序
好多人开始学:UNIX 环境高级编程这本书时:看到书里面说的头文件ourhdr.h而找不到她在哪里:而且无法开始继续学习:其实这个就是系统的内核标准头文件: 而她的位置在:/usr/include/u ...
- 推荐几篇关于EF的好文章
文章作者 Julie Lerman 是 Microsoft MVP..NET 导师和顾问,住在佛蒙特州的山区.您可以在全球的用户组和会议中看到她对数据访问和其他 .NET 主题的演示.她的博客地址是 ...
- 【荐】如何规划 Nginx 网站目录的权限(用户,用户组,ssh,sftp)
从上一篇文章:PHP网站(nginx.php-fpm.mysql) 用户权限解析,可以学习了解到,nginx 和 php-fpm 的用户是如何运作的. 有个工作场景: 1.公司的一台 CentOS 服 ...
- Python之路【第二十一篇】Django ORM详解
ORM回顾 关系对象映射(Object Relational Mapping,简称ORM). django中遵循 Code Frist 的原则,即:根据代码中定义的类来自动生成数据库表. 对于ORM框 ...
随机推荐
- phpmyadmin新加用户登陆不了,测试解决方案。
今天在给项目配置数据库管理平台时遇到一个问题,不论怎么添加mysql用户在登陆phpmyadmin时始终无法登陆,不管准不准许为空依然报出#1045 无法登陆服务器的错误,最后打开mysql库中use ...
- python处理汉字转拼音pypinyin
主要是pypinyin 包,官网: http://pypinyin.readthedocs.io/zh_CN/master/index.html jieba包,主要是用来分词的,我之前的博文有介绍:h ...
- 【POJ】1704.Georgia and Bob
题解 感觉挺神奇的 我们把石子从后往前相邻的两个两两配对,这样他们之间的空格就相当于一堆石子 而配对后左边棋子移动,右边棋子也一定可以跟上取 转化成简单的nim游戏,最后只要看转化出的这(N - 1) ...
- thinkphp3.2开启静态缓存与缓存规则设置
网站的静态缓存对大访问量有很好的缓解作用,尤其对网站的大并发,可有效的缓解数据库的压力.在thinkphp中实现静态缓存很简单,thinkphp都已经封装好了直接调用即可. 静态缓存 首先设置 H ...
- JAVAEE——宜立方商城04:图片服务器FastDFS、富文本编辑器KindEditor、商品添加功能完成
1. 学习计划 1.图片上传 a) 图片服务器FastDFS b) 图片上传功能实现 2.富文本编辑器的使用KindEditor 3.商品添加功能完成 2. 图片服务器的安装 1.存储空间可扩展. 2 ...
- Linux C函数库参考手册
目录 第1章 字符测试函数 isalnum(测试字符是否为英文字母或数字) isalpha(测试字符是否为英文字母) isascii(测试字符是否为ascii码字符) isblank(测试字符是否为空 ...
- mysql 通过cmd 在命令行创建数据库
一.连接MYSQL 格式: mysql -h主机地址 -u用户名 -p用户密码 1. 连接到本机上的MYSQL. 首先打开DOS窗口,然后进入目录mysql\bin,再键入命令mysql -u roo ...
- 排序算法之冒泡排序Java实现
排序算法之冒泡排序 舞蹈演示排序: 冒泡排序: http://t.cn/hrf58M 希尔排序:http://t.cn/hrosvb 选择排序:http://t.cn/hros6e 插入排序:ht ...
- codevs 2596 售货员的难题
2596 售货员的难题 时间限制: 1 s 空间限制: 32000 KB 题目等级 : 钻石 Diamond 题目描述 Description 某乡有n个村庄(1<n<=15),有一个售货 ...
- 【贪心】【堆】Gym - 101775B - Scapegoat
题意:有n个事件,每个事件有一个严重程度,m个人(m>=n),你要让m个人去背锅,每个人只能背一个事件的锅,但是一个事件可以由很多人背.让你使得这m个人所承受的严重程度的方差最小化. 考虑一开始 ...