gpt4 book ai didi

将 bin 文件中的字符串编译为 fgets() 字符串

转载 作者:行者123 更新时间:2023-11-30 14:32:27 25 4
gpt4 key购买 nike

在我的代码中,我创建了 3 个新文件。

如果文件“users”不存在,我会创建一个包含一些信息的文件来初始化该文件。

之后,我想使用 fgets() 函数比较用户的字符串然后将字符串与文件中的字符串进行比较(密码和 ID)您可以在代码开头看到 struct: user。现在,当我使用“strcmp”时,它总是给我“1”。

enter code here

#define CRT_SECURE_NO_WARNINGS
#pragma warning(disable:4996)
#include <stdio.h>
#include <stdbool.h>
#include <time.h>
#include "doubly_list.h"

typedef struct user {
int SecurityLevel;
char ID[15];
char Password[15];
char FullName[20];
}user;

typedef struct items {
char movie_name[20];
char producer_name[20];
int release_date_year, release_date_month, release_date_day;
float rating;
int serial_number;
bool is_adult_video;
}items;

void main()
{
char id_input[15], password_input[15];
int day, month, year, hours, mins, SecurityLevel;


FILE* log;
log = fopen("log.txt", "a");
fclose(log);

FILE* users;
users = fopen("users.dat", "rb+");

user new_user;
if (users == NULL)
{
FILE* users;
users = fopen("users.dat", "ab+");
new_user.SecurityLevel = 3;
strcpy(&new_user.Password, "admin");
strcpy(&new_user.ID, "admin");
strcpy(&new_user.FullName, "System_Manager");
fwrite(&new_user, sizeof(new_user), 1, users);
fclose(users);
}


FILE* item;
item = fopen("users.dat", "ab+");
fclose(item);

printf("Enter ID: ");
fgets(id_input, 15, stdin);
flushall();
printf("Enter Password : ");
fgets(password_input, 15, stdin);

log = fopen("log.txt", "a+");
fprintf(log, "\nthe user entered the ID : %s", id_input);
fprintf(log, "the user entered the password : %s", password_input);

FILE* users_out= fopen("users.dat", "rb");
fread(&new_user, sizeof(user), 1, users_out);

int result= result = strcmp(password_input, new_user.Password);
printf("\n%d\n", result);

if (strcmp(password_input, new_user.Password)==0)
printf("\nLog in was successful.....\n\n");
else
printf("\nLog In was Unseccessful.....\n\n");

fclose(log);
fclose(users_out);

system("pause");
}

最佳答案

代码使用了fgets(),但未能删除尾随的'\n'。而且输入缓冲区至少小了 1

printf("Enter ID: ");
fgets(id_input, 15, stdin); // likely has \n in `id_input`.

而是考虑一个辅助函数,例如

// read a line of input
// 1: Success
// 0: bad input
// EOF: end-of-file or rare input error
int read_line80(const char *prompt, char *dest, size_t sz) {
char buf[80 * 2]; // Be generous to allow for casual over long input
// If VLAs allowed, consider `char buf[sz + 2];`

if (prompt) fputs(prompt, stdout);
fflush(stdout); // Make certain output seen before input

if (sz > 0) dest[0] = '\0';
if (fgets(buf, sizeof buf, stdin) == NULL) return EOF;

size_t len = strlen(buf);
if (len > 0 && buf[len-1] == '\n') {
buf[--len] = '\0';
}

// Maybe add extra code here to see if `fgets()` did not read everything

if (len >= sz) return 0;
strcpy(dest, buf);
return 1;
}

然后

    if (read_line("Enter ID: ", id_input, sizeof id_input == 1) &&
read_line("Enter Password : ", password_input, sizeof password_input == 1)) {
// Oh happy day!
// Use input
} else {
// Fail
}

关键点是用户输入是邪恶的,最好在辅助函数中读取输入并让它处理 I/O 细微差别。让调用代码专注于输入的非 I/O 方面。

关于将 bin 文件中的字符串编译为 fgets() 字符串,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59802303/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com