需要编辑哪些文件才能将新用户添加到ubuntu?

时间:2014-08-13 03:18:41

标签: c linux permissions ubuntu-14.04

我正在尝试编写一个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的情况下运行程序?

我需要在代码中添加哪些更改?

2 个答案:

答案 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用户身份运行,这在做之前总是需要了解。