4.11. chown,fchown, and lchown Functions
在做实验之前,因为操作vim和bash环境设置的问题搞了好长时间,总算勉勉强强顺手了。不过vim操作和bash脚本编程,.vimrc和.bashrc编写确实要抽时间来熟悉一下。
本例的初衷是为了理解上面那几个函数,不过我想功能应该是差不多的,于是就只选取了chown来做实验。
实验代码如下:
#include <stdio.h>
#include <unistd.h>
#include "apue.h"
#include "myerr.c"
#include <pwd.h>
#ifdef _POSIX_CHOWN_RESTRICTED
#undef _POSIX_CHOWN_RESTRICTED
#endif
#define _POSIX_CHOWN_RESTRICTED 0
int
main (int argc, char *argv[])
{
uid_t uid ;
struct passwd *pwdp ;
int i, j ;
char *endptr ;
char bSuccess ;
if (argc != 3)
err_quit ("usage : a.out <attribute> <filename> ...\n") ;
printf ("current user id :\t\t %d\n", getuid ()) ;
printf ("current group id :\t\t %d\n", getgid ()) ;
printf ("current effective user id :\t %d\n", geteuid ()) ;
printf ("current effective ground id :\t %d\n", getegid ()) ;
uid = strtol (argv[1], &endptr, 0) ;
if (*endptr != '\0') { // user name
if ((pwdp = getpwnam (argv[1])) == NULL)
err_msg ("getpwnam error : ") ;
} else {
if ((pwdp = getpwuid (uid)) == NULL)
err_msg ("getpwuid error : ") ;
}
puts ("\nuser/group info by getpwnam/getpwuid function:") ;
printf ("user : %s\n", pwdp->pw_name) ;
printf ("pwd : %s\n", pwdp->pw_passwd) ;
printf ("uid : %d\n", pwdp->pw_uid) ;
printf ("gid : %d\n", pwdp->pw_gid) ;
printf ("uifo : %s\n", pwdp->pw_gecos) ;
printf ("home : %s\n", pwdp->pw_dir) ;
printf ("shell: %s\n", pwdp->pw_shell) ;
printf ("-------\n") ;
printf ("_POSIX_CHOWN_RESTRICTED : %ld\n",
pathconf (argv[2], _PC_CHOWN_RESTRICTED)) ;
if (chown (argv[2], pwdp->pw_uid, -1) == -1)
err_ret ("chown for uid error ") ;
else
printf ("success to change uid") ;
putchar ('\n') ;
if (chown (argv[2], -1, pwdp->pw_gid) == -1)
err_ret ("chown for gid error ") ;
else
printf ("success to change gid") ;
putchar ('\n') ;
exit (0) ;
}
此代码类似于bash的chown命令。从控制台接收三个参数,第一个是程序名,第二个是新的用户名或群组名,第三个是文件名。
第一部分,先输出当前用户的信息(uid,gid,euid,egid);
第二部分,输出新的用户名或群组名的信息,与/etc/passwd保持一致;
第三部分,输出_POSIX_CHOWN_RESTRICTED的值,看系统是否对chown的功能进行了限制;
第四部分,输出是否能改变文件的uid和gid。
实验结果表明,Fedora中对chown的功能是有限制的_POSIX_CHOWN_RESTRICTED被定义为1.
对于非特权用户,只能改变自己文件的所属group,不能改变文件所属者,但可以将自己的文件改变为自己……(听起来很那个= =!)