我获得了用户ID以将其添加到文件路径中。但是我在创建文件时遇到了麻烦。如何将用户标识添加到文件路径?我使用strcpy
,但这似乎不起作用。这是我的代码。
mode_t mode = S_IRUSR | S_IWUSR | S_IRGRP | S_IROTH;
register struct passwd *pw;
register uid_t uid;
uid = geteuid ();
pw = getpwuid (uid);
char str[1000];
strcpy(str, "/home/" );
strcpy(str, pw->pw_name );
strcpy(str, "/Documents/test.txt" );
int openFile = creat(str, mode);
答案 0 :(得分:4)
三次strcpy()?也许你想要:
strcpy(str, "/home/");
strcat(str, pw->pw_name);
strcat(str, "/Documents/test.txt");
?甚至更好:
int ret;
ret = snprintf(str, sizeof str, "%s/%s/%s"
, "/home" , pw->pw_name, "Documents/test.txt");
if (ret >= sizeof str) {... error...}
答案 1 :(得分:1)
这是snprintf的一个很好的目的(在stdio.h中)。一行:
snprintf(str, 1000, "/home/%s/Documents/test.txt", pw->pw_name);
最好先验证pw-> pw_name先前是否为空。
您的多个strcpy不起作用的原因是您在每次调用时写入内存中的相同位置。
我不建议您这样做,但如果您在每次调用后更新指针,则可以使用strcpy。一个例子:
char *loc = str;
strcpy(loc, "/home/" );
loc += strlen("/home/");
strcpy(loc, pw->pw_name );
loc += strlen(pw->pw_name);
strcpy(loc, "/Documents/test.txt" );
但是,如果您选择了一个小缓冲区(短于所有三个字符串的字符组合数,再多一个用于终止空值),这将是一个问题 - 缓冲区溢出。
snprintf提供了确保您不超过该界限的好处:
函数snprintf()和vsnprintf()写入的字节数不超过大小(包括终止空字节('\ 0'))。