wwater 2017-05-24
0.环境平台
操作系统平台:
Linux leaf 4.4.0-75-generic #96-Ubuntu SMP Thu Apr 20 09:56:33 UTC 2017 x86_64 x86_64 x86_64 GNU/Linux
相关工具语言:vim,gcc,C语言
1.程序源代码
linux@linuxidc:~/operation/1$ cat pflag.c
#include <unistd.h>
#include <pwd.h>
#include <sys/types.h>
#include <stdio.h>
int
main(
int
argc,
char
**argv)
{
pid_t my_pid,parent_pid;
uid_t my_uid,my_euid;
gid_t my_gid,my_egid;
struct
passwd *my_info;
my_pid=getpid();
parent_pid=getppid();
my_uid=getuid();
my_euid=geteuid();
my_gid=getgid();
my_egid=getegid();
my_info=getpwuid(my_uid);
printf
(
"Process ID:%ld\n"
,my_pid);
printf
(
"Parent ID:%ld\n"
,parent_pid);
printf
(
"User ID:%ld\n"
,my_uid);
printf
(
"Effective User ID:%ld\n"
,my_euid);
printf
(
"Group ID:%ld\n"
,my_gid);
printf
(
"Effective Group ID:%ld\n"
,my_egid);
if
(my_info)
{
printf
(
"My Login Name:%s\n"
,my_info->pw_name);
printf
(
"My Password:%s\n"
,my_info->pw_passwd);
printf
(
"My User ID:%ld\n"
,my_info->pw_uid);
printf
(
"My Group ID:%ld\n"
,my_info->pw_gid);
printf
(
"My Real Name:%s\n"
,my_info->pw_gecos);
printf
(
"My Home Dir:%s\n"
,my_info->pw_dir);
printf
(
"My Work Shell:%s\n"
,my_info->pw_shell);
}
}
2.程序编译与执行
编译:
linux@linuxidc:~
/operation/1
$ gcc pflag.c -o pflag
编译后会生成pflag程序,执行该程序(为了方便后面的结果分析,执行两次):
linux@linuxidc:~
/operation/1
$ .
/pflag
Process ID:12628
Parent ID:10136
User ID:1000
Effective User ID:1000
Group ID:1000
Effective Group ID:1000
My Login Name:linuxidc
My Password:x
My User ID:1000
My Group ID:1000
My Real Name:linuxidc,,,
My Home Dir:
/home/linuxidc
My Work Shell:
/bin/bash
linux@linuxidc:~
/operation/1
$
linux@linuxidc:~
/operation/1
$ .
/pflag
Process ID:12695
Parent ID:10136
User ID:1000
Effective User ID:1000
Group ID:1000
Effective Group ID:1000
My Login Name:linuxidc
My Password:x
My User ID:1000
My Group ID:1000
My Real Name:linuxidc,,,
My Home Dir:
/home/linuxidc
My Work Shell:
/bin/bash
3.结果分析
(1)进程标志
因为pflag程序的两次执行都是在同一shell进程下完成的,所以显然输出的Parent ID都是一致的,但是每次程序执行完成后,相应的程序进程也会结束,所以两次程序执行的Process ID都是不一样的。
(2)用户信息
使用了两种方式去获取用户信息,一种是直接取单独的用户信息,如取User ID,直接调用函数库中的函数getuid()函数;而另外一种则是通过创建passwd结构体的实例my_info来直接获取所有的相关用户信息。
分析上面的结果,再与Linux操作系统上的/etc/passwd上本用户的信息进行比对:
linux@linuxidc:~
/operation/1
$
grep
'linuxidc'
/etc/passwd
linuxidc:x:1000:1000:linuxidc,,,:
/home/linuxidc
:
/bin/bash
# 输出依次为
# 用户名:用户密码(不使用,用x代替):用户ID:用户组ID:用户真实姓名:用户家目录:用户shell
可以发现,通过系统调用的方式来获取这些参数,与Linux操作系统/etc/passwd文件记录的信息内容是一致的。