我在寻找如何在C程序中使用的realpath函数的一个例子。 我似乎无法找到一个在网络上或在我的任何C语言编程的书籍。
Answer 1:
的realpath()
函数不是在C标准中描述。 它是由描述。然而1997年POSIX和2008 POSIX 。 如果这是你的意思,这里是一个例子:
#include <limits.h> /* PATH_MAX */
#include <stdio.h>
#include <stdlib.h>
int main(void) {
char buf[PATH_MAX + 1]; /* not sure about the "+ 1" */
char *res = realpath("this_source.c", buf);
if (res) {
printf("This source is at %s.\n", buf);
} else {
perror("realpath");
exit(EXIT_FAILURE);
}
return 0;
}
PATH_MAX中定义<limits.h>中 ( <limits.h>中从POSIX 1997 )
Answer 2:
单行build命令行
极简主义,但它的工作!
建立
gcc -o realpath -x c - <<< $'#include<stdlib.h>\n#include<stdio.h>\nint main(int c,char**v){puts(realpath(v[1],0));}'
测试
$> ./realpath ~/../../../usr/./bin/./awk
/bin/gawk
$> readlink -f ~/../../../usr/./bin/./awk
/bin/gawk
要求
- GCC编译和链接
- 庆典为
<<<
和$' ... \n ... '
紧急
我的极简单行命令行构建的可执行realpath
产生一个Segmentation fault
时的路径不存在。 而不是写的if
/ else
集团到我的回答中处理这个问题,我在下面的一些链接添加到让你对Busybox的执行情况看realpath
和readlink
。
Busybox的实施
有关更完整的源代码,对这个简单的实现看看。
官方Git仓库
-
coreutils/realpath.c
-
coreutils/readlink.c
-
libbb/xreadlink.c
GitHub的仓库镜像
-
coreutils/realpath.c
-
coreutils/readlink.c
-
libbb/xreadlink.c
Answer 3:
什么是realpath()
函数的作用是告诉你一个文件的路径时,所有符号链接都得到了解决。 它不一定是一个绝对路径,如果你提供的价值是相对的名字,但部分取决于你是否穿越与链接值绝对名称的任何符号链接 - 如果你这样做,那么输出是一个绝对的名字毕竟。 此外,如果相对名称遍历到根目录(或“超越”,如“../../../../../ ..”当在目录层次深只有三个级别)。
你可能有一个“真实路径”计划已经在你的机器上。 这里的(非标)版本,我写的。
/*
@(#)File: $RCSfile: realpath.c,v $
@(#)Version: $Revision: 1.3 $
@(#)Last changed: $Date: 2007/10/23 20:23:44 $
@(#)Purpose: Command to evaluate realpath(3) on given arguments.
@(#)Author: J Leffler
@(#)Copyright: (C) JLSS 2007
@(#)Product: :PRODUCT:
*/
/*TABSTOP=4*/
#if __STDC_VERSION__ >= 199901L
#define _XOPEN_SOURCE 600
#else
#define _XOPEN_SOURCE 500
#endif /* __STDC_VERSION__ */
#include <unistd.h>
#include <limits.h>
#include <stdio.h>
#include <stdlib.h>
#include "stderr.h"
static const char optstr[] = "hlsV";
static const char usestr[] = "[-hslV] given-path [...]";
static const char hlpstr[] =
" -h Print this help message\n"
" -l Long format: print given-path and real-path\n"
" -s Short format: print just real-path\n"
" -V Print version and exit\n"
;
enum { FMT_LONG, FMT_SHORT };
static int format_type = FMT_LONG;
#ifndef lint
/* Prevent over-aggressive optimizers from eliminating ID string */
extern const char jlss_id_realpath_c[];
const char jlss_id_realpath_c[] = "@(#)$Id: realpath.c,v 1.3 2007/10/23 20:23:44 jleffler Exp $";
#endif /* lint */
static int eval_realpath(const char *given)
{
char realname[_POSIX_PATH_MAX];
int rc = 0;
if (realpath(given, realname) == 0)
{
rc = -1;
err_sysrem("failed to resolve real path name for %s\n", given);
}
else if (format_type == FMT_SHORT)
printf("%s\n", realname);
else
printf("%s %s\n", given, realname);
return(rc);
}
int main(int argc, char **argv)
{
int i;
int rc = EXIT_SUCCESS;
int opt;
err_setarg0(argv[0]);
while ((opt = getopt(argc, argv, optstr)) != -1)
{
switch (opt)
{
case 'V':
err_version("REALPATH", &"@(#)$Revision: 1.3 $ ($Date: 2007/10/23 20:23:44 $)"[4]);
break;
case 'h':
err_help(usestr, hlpstr);
break;
case 'l':
format_type = FMT_LONG;
break;
case 's':
format_type = FMT_SHORT;
break;
default:
err_usage(usestr);
break;
}
}
for (i = optind; i < argc; i++)
{
if (eval_realpath(argv[i]) != 0)
rc = EXIT_FAILURE;
}
return(rc);
}
我需要它来测试一些软件,被评估的路径的安全性,以确保我的代码被评估到同一个解决位置作为给定的路径所需realpath()
一样。 或许,这将是明智的(通过在前面的结果,将其与“-a”选项延长,以确保名称映射到绝对名称getcwd()
到相对路径)。
(来源为stderr.c,stderr.h可以在网上,如果你知道去哪里找或者联系我发现 - 见我的个人资料)
Answer 4:
像这样:
int main(int argc, char *argv[]) {
...
char *symlinkpath = argv[1];
char actualpath [PATH_MAX];
char *ptr;
ptr = realpath(symlinkpath, actualpath);
...
}
从借用这里