0
int main(void){
 int n, user_length;
 char userid[30];
 char password[11];

 if ((n = read(STDIN_FILENO, userid, 10)) == -1) {
    perror("read");
    exit(1);
} else if(n == 0) {
    fprintf(stderr, "Error: could not read from stdin");
    exit(1);
}
if (userid[n-1] == '\n')
    userid[n-1] = '\0';
else
    userid[n] = '\0';

if ((n = read(STDIN_FILENO, password, 10)) == -1) {
    perror("read");
    exit(1);
} else if (n == 0) {
    fprintf(stderr, "Error: could not read from stdin");
    exit(1);
}
if (password[n-1] == '\n')
    password[n-1] = '\0';
else
    password[n] = '\0';

strcat(userid, ":");
user_length = strlen(userid);
strcat(userid, password);
FILE *fp = fopen(PASSWORD_FILE, "r");
if (!fp) {
    perror("fopen");
    exit(1);
}
char line[MAXLINE];
while(fgets(line, sizeof(line) - 1, fp)) {
    line[strlen(line) - 1] = '\0';
    if (strcmp(userid, line) == 0)
        exit(0); // found match
    else if(strncmp(userid, line, user_length) == 0)
        exit (2); // invalid password
 }
 exit(3); // no such user
}

上記はvalidate.cの実装ですが、pipe()、dup2、execl()を使って関数にユーザーIDやパスワードなどの値を渡すにはどうすればよいですか

私は次のものを使用しました`

int main(void) {
    char userid[10];
    char password[10];
    int   pid;
    int p[2][4];
   char other[MAXSIZE];

/* Read a user id and password from stdin */
   printf("User id:\n");
    scanf("%s", userid);
printf("Password:\n");
scanf("%s", password);
/*Your code here*/
if (pipe(p[1]) == -1) {
    perror("pipe");
}
if (pipe(p[0]) == -1) {
    perror("pipe");
}
pid = fork();
if (pid != 0) {


  close(p[1][0]);
  close(p[0][0]);

  dup2(p[1][1],STDIN_FILENO);
  dup2(p[0][1],STDIN_FILENO);

  close(p[1][1]);
  close(p[0][1]);


  int status;
  if (wait(&status)!= -1)  {
    if (WIFEXITED(status)) {
      printf("[%d] Child exited with %d\n", getpid(),  WEXITSTATUS(status));
      switch(WEXITSTATUS(status)){
        case 0:
          printf("found match\n");
          break;
        case 2:
          printf("invalid password\n");
          break;
        case 3:
          printf("No such user\n");
          break;
        default:
          printf("error has occur\n");
          break;
      };

    } else {
      printf("[%d] Child exited abnormally\n", getpid());
    }
  }
} else if (pid == 0) {

  close(p[1][1]);
  close(p[0][1]);
  dup2(p[1][0], fileno(stdout));
  dup2(p[1][0], fileno(stdout));
  execl("validate",other);
  printf("what\n");

  close(p[1][0]);
  close(p[0][0]);

} else {
  perror("fork");
  exit(1);
}
return 0;

}

しかし、プロンプトは常に入力を再入力するように求めます。このアプローチの何が問題なのですか?

4

1 に答える 1

1

コメントで述べたように、おそらくこれのために別のプロセスを生成する必要はありませんが、execl を呼び出す方法にエラーがあります。

これ:

execl("validate",other);

次のようにする必要があります。

execl(filename,list of arguments, NULL);

これはドキュメントページです。NULL を使用するのと同じ (char *) 0 を使用します。

于 2016-07-14T22:13:22.973 に答える