如何使用mount(2)通过afp挂载目录?

时间:2017-05-26 19:50:41

标签: c++ macos mount afp

我想挂载一个位于我网络上另一台主机上的目录。到目前为止,我已成功通过afp通过系统调用使用mount(8)执行此操作,如下所示:

std::string syscmd = "mount -v -t afp -r \"afp://user:password@host/dir\" \"/tmp/foo/bar\"";
FILE *fd;
if(!(fd = popen(syscmd.c_str(), "r"))) {
    std::cout << "oops. popen() failed." << std::endl;
    exit(1);
}    

但是我想直接使用函数调用挂载,而无需使用popen()调用shell的额外开销。我无法弄清楚如何使用具有此签名的mount(2)来执行此操作:

 int mount(const char *type, const char *dir, int flags, void *data);

data应该是什么?手册页没有详细解释这一点。例如,它说:

  

Data是指向包含特定类型的结构的指针   mount的参数。这些参数结构的格式是   在每个文件系统的手册页中进行了描述。

它指的是哪个手册页?还有其他一些我遗漏的文件吗?有人能指出一个简单的工作示例来说明mount(2)在afp上的使用吗?有更好的方法吗?

1 个答案:

答案 0 :(得分:0)

您是否有理由要求通过mount(2)完成?

Apple从NetFS框架提供NetFSMountURLSync()功能,以安装网络文件系统。遗憾的是,唯一的文档是头文件,所以我无法链接到它,但这里是相关的声明:

/*
 * Given a URL that refers to a file server, connect to that server
 * and mount stuff.
 *
 * If the URL just specifies a server and you can't just mount the
 * "root directory" of the server, the user will be prompted with
 * a window to let them select one or more items to mount from that
 * server, otherwise whatever item the URL specifies to mount will
 * be mounted.
 *
 * If the mountpath is provided it will be used as the mount point.
 * If the mountpath is set to NULL, a default mount point will be used.
 *
 * If the user and passwd are set, they will override any user name
 * or password that may be set in the URL. These calls go through the NetAuth agent.
 * If the URL doesn't specify a password, and one is needed, the
 * user will be prompted with a window requesting password.
 *
 * Options can be provided for the session open and the mount itself.
 * If the mount is successful, the POSIX path to each mountpoint is
 * returned as a CFStringRef in mountpoints.
 *
 * If the return value is zero the mount has succeeded.
 *
 * A positive non-zero return value represents an errno value
 * (see /usr/include/sys/errno.h).  For instance, a missing mountpoint
 * error will be returned as ENOENT (2).
 *
 * A negative non-zero return value represents an OSStatus error.
 * For instance, error -128 is userCanceledErr, returned when a mount
 * operation is canceled by the user. These OSStatus errors are
 * extended to include:
 *
 *  from this header:
 *  ENETFSPWDNEEDSCHANGE        -5045
 *  ENETFSPWDPOLICY         -5046
 *  ENETFSACCOUNTRESTRICTED     -5999
 *  ENETFSNOSHARESAVAIL     -5998
 *  ENETFSNOAUTHMECHSUPP        -5997
 *  ENETFSNOPROTOVERSSUPP       -5996
 *
 *  from <NetAuth/NetAuthErrors.h>
 *  kNetAuthErrorInternal       -6600
 *  kNetAuthErrorMountFailed    -6602
 *  kNetAuthErrorNoSharesAvailable  -6003
 *  kNetAuthErrorGuestNotSupported  -6004
 *  kNetAuthErrorAlreadyClosed  -6005
 *
 */
int
NetFSMountURLSync(
    CFURLRef url,               // URL to mount, e.g. nfs://server/path
    CFURLRef mountpath,         // Path for the mountpoint
    CFStringRef user,           // Auth user name (overrides URL)
    CFStringRef passwd,             // Auth password (overrides URL)
    CFMutableDictionaryRef open_options,    // Options for session open (see below)
    CFMutableDictionaryRef mount_options,   // Options for mounting (see below)
    CFArrayRef *mountpoints)        // Array of mountpoints
    __OSX_AVAILABLE_STARTING(__MAC_10_8, __IPHONE_NA);

如果它对您的用例有用,那么它也是异步版本。

this answer所示,如果要指定挂载点,则需要使用kNetFSMountAtMountDirKey选项。