之前从未关注过Linux的密码机制,最近看书刚刚好看到这里了,顺便写一下,免得以后还需要单独查询。<br>
Linux密码文件:<br>
Linux中是这样的,密码文件保存在/etc/passwd文件中,在http://www.phpjiayuan.com/82/204.html这里有相对详细的介绍,我在此就不再赘述了,但是需要指出的是,用户的密码是经过加密的,而且是单向加密,这种加密类似于MD5的加密,一般来说只有通过字典爆破才可能。<br>
讲了这么多废话,那么我们怎么在程序中获得我们需要的密码呢?<br>
Linux提供了这样两个函数:<br>
#include <pwd.h><br>
struct passwd* getpwuid(uid_t uid);<br>
struct passwd* getpwnam(const char *name);<br>
对于前者,也就是getpwuid函数是由ls程序使用的,它将I节点的数字用户名(准确的说是用户ID,也就是前文提到的),在/etc/passwd文件中列出来的第一列;后者在用户登录系统时,由login()程序使用,然后加密比对,从而完成登录密码校验过程。事实上,在我们具体的程序中完全可以通过这两个函数获取我们想要的东西。<br>
这是通过man 找到的passwd结构体的组成如下:
struct passwd
{
char *pw_nmae; /*user name*/<br>
char *pw_password; /*user password*/
uid_t pw_uid; /*user ID*/
gid_t pw_gid /*user group ID*/
char *pw_gecos; /*user info*/
char *pw_dir; /*home path*/
char *pw_shell; /*shell program*/
}