我正在尝试编写一个C程序来向我的Ubuntu 14.04添加新用户。 我编辑了
1)/ etc / passwd
sachin:x:65535:1:sachin:/home/sachin:/bin/bash
2)/ etc / shadow
sachin:$6$VwBWgroA$t4KXLWIf81sWtiA1/a.fRLrXaOAflGtMo73hGvCzp/M6S8oizZ4iqk.vYbkblXZj2hgGXJxlJ.M2hghGO.a650:16294::::::
3).profile
stty istrip
PATH=/bin:/usr/bin:/usr/local/bin:/usr/share/bin:.
export PATH
此后我跑 - ls -l / home /
drwxr-xr-x 43 mrcr mrcr 4096 Aug 12 10:27 mrcr
d-w------t 2 sachin sachin 4096 Aug 12 11:11 sachin
我的rpogram创建了“sachin”,正常创建“mrcr”。我像普通用户家一样更改了权限
drwxr-xr-x 2 sachin sachin 4096 Aug 12 11:11 sachin
我将所有文件从“mrcr”主目录复制到“sachin”主目录(.bashrc,Desktop ..etc)
现在登录界面“sachin”即可登录。但即使我输入正确的密码,我也无法登录。它将再次加载相同的登录屏幕。下面给出的是我的整个代码,
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#include <sys/types.h>
#include <pwd.h>
#include<signal.h>
#include<unistd.h>
main(int argc, char **argv)
{
struct passwd *userlist;
int count, usernumber, len1;
FILE *tmp, *stmp, *mailer, *profile;
char *commentfield, *username, *userdir, *home;
char *mailcomment, *mailmail, reply;
commentfield = (char *)malloc(1024*sizeof(char));
username = (char *)malloc(8*sizeof(char));
userdir = (char *)malloc(256*sizeof(char));
home = (char *)malloc(256*sizeof(char));
mailcomment = (char *)malloc(1024*sizeof(char));
mailmail = (char *)malloc(512*sizeof(char));
if (argc!=4)
{
printf("usage : %s [dirname- no slashes] [logname] [comment - in quotes]\n", argv[0]);
exit(1);
}
if( (strlen(argv[2]) < 5) || (strlen(argv[2]) > 8) )
{
printf("pls enter logname between 5-8 \n");
exit(1);
}
signal(SIGHUP, SIG_IGN);
signal(SIGINT, SIG_IGN);
setpwent();
count = 0;
while((userlist = getpwent()) != NULL)
{
if(count < userlist->pw_uid)
{
count = userlist->pw_uid ;
usernumber = count + 1;
}
}
printf("usernumber : %d\n", usernumber);
endpwent();
sprintf(commentfield,"%s", argv[3]);
sprintf(username, "%s", argv[2]);
sprintf(userdir, "%s", argv[1]);
sprintf(home, "/%s/%s", argv[1], argv[2]);
printf("\n Check this out here: \n");
printf("-----------------------------------------------");
printf("\n username :\t %s", username);
printf("\n Home Directory:\t %s", home);
printf("\n comment :\t %s", commentfield);
printf("\n______________________________________________\n\n");
printf("all of this ok? n/y: ");
scanf("%c", &reply);
if(reply != 'y')
{
printf("\n exiting....u entered not y");
exit(1);
}
tmp = fopen("/etc/passwd", "a");
if (tmp == NULL)
{
printf("\npermission denied\n");
exit(1);
}
fprintf(tmp, "%s:x:%d:1:%s:%s:/bin/bash\n", username, usernumber, commentfield, home);
fclose(tmp);
stmp = fopen("/etc/shadow", "a");
if (stmp == NULL)
{
printf("\npermission denied\n");
exit(1);
}
fprintf(stmp, "%s:*LK*:::::::\n", username);
fclose(stmp);
mkdir(home, 0755);
chdir(home);
profile = fopen(".profile", "a");
fprintf(profile, "stty istrip\n");
fprintf(profile, "PATH=/bin:/usr/bin:/usr/local/bin:/usr/share/bin:.\n");
fprintf(profile, "export PATH\n");
fprintf(profile, "\n\n");
fclose(profile);
chown(home, usernumber, 1);
chown(".profile", usernumber, 1);
chmod(".profile", 0644);
printf("\n\nALL done!!!!!!!\n Now set the password: ");
execl("/usr/bin/passwd", "passwd", username, NULL);
printf("\n\n SUCCESS PASSWORD IS SET.....BYE!!!\n\n");
}
问题:
需要编辑哪些文件?
如何在不成为root的情况下运行程序?
我需要在代码中添加哪些更改?
答案 0 :(得分:2)
这可能不会直接回答你的问题,但我认为很重要 - 因为Unix命令通常会有很好的测试和定义的函数,几乎可以完成创建,编辑和删除用户所需的一切,我认为你应该不要试图自己重新创建一个。除了可能出错的其他事情之外,我认为如果不使用操作系统中包含的实用程序,您可以成功编辑/etc/shadow
。我可以给你的最好的建议(有些可能不同意,但对我来说似乎更好)恕我直言,用useradd
代码中的所需参数调用C
命令,而不是再次尝试创建轮子。
答案 1 :(得分:0)
这听起来像一个有趣的项目!
我正在运行Arch,所以我不能给你确切的答案,但我做的是检查它是创建一个文件来标记时间,添加一个用户,然后找到自启动文件以来修改的所有文件创建了:
$ touch start
$ useradd -m temp
$ find / -cnewer start -print
您可以登录find
(即只搜索/etc
或可能有更改的文件夹),但最后看起来您正在触摸所有正在更改的主文件夹,{{{ 1}}和/etc/gshadow
。
同时阅读/etc/group
的手册页,看起来您可能需要查看useradd
和/etc/subgid
,因为它们会处理群组和用户ID。
关于在没有sudo的情况下运行代码的问题,您可以考虑设置SUID or GUID bits。这将使您在正常情况下以root身份运行代码。请记住作为普通用户,您将以root用户身份运行,这在做之前总是需要了解。