WNetGetConnectionA 函数 (winnetwk.h)

WNetGetConnection 函数检索与本地设备关联的网络资源的名称。

语法

DWORD WNetGetConnectionA(
  [in]      LPCSTR  lpLocalName,
  [out]     LPSTR   lpRemoteName,
  [in, out] LPDWORD lpnLength
);

参数

[in] lpLocalName

指向常量以 null 结尾的字符串的指针,该字符串指定要为其获取网络名称的本地设备的名称。

[out] lpRemoteName

指向一个以 null 结尾的字符串的指针,该字符串接收用于建立连接的远程名称。

[in, out] lpnLength

指向一个变量的指针,该变量指定 lpRemoteName 参数所指向的缓冲区的大小(以字符为单位)。 如果函数由于缓冲区不够大而失败,则此参数返回所需的缓冲区大小。

返回值

如果函数成功,则返回值NO_ERROR。

如果函数失败,则返回值为 系统错误代码,例如以下值之一。

返回代码 描述
ERROR_BAD_DEVICE
lpLocalName 参数指向的字符串无效。
ERROR_NOT_CONNECTED
lpLocalName 指定的设备不是重定向的设备。 有关详细信息,请参阅以下“备注”部分。
ERROR_MORE_DATA
缓冲区太小。 lpnLength 参数指向包含所需缓冲区大小的变量。 后续调用提供了更多条目。
ERROR_CONNECTION_UNAVAIL
设备当前未连接,但它是永久性连接。 有关详细信息,请参阅以下“备注”部分。
ERROR_NO_NETWORK
网络不可用。
ERROR_EXTENDED_ERROR
发生了特定于网络的错误。 若要获取错误的说明,请调用 WNetGetLastError 函数。
ERROR_NO_NET_OR_BAD_PATH
任何提供程序都无法将本地名称识别为具有连接。 但是,该网络不适用于连接可能所属的至少一个提供程序。

言论

如果使用 Microsoft LAN Manager 网络建立网络连接,并且调用应用程序在与建立连接的应用程序不同的登录会话中运行,则对关联的本地设备的 WNetGetConnection 函数的调用将失败。 函数失败并ERROR_NOT_CONNECTED或ERROR_CONNECTION_UNAVAIL。 这是因为使用 Microsoft LAN 管理器建立的连接仅对与建立连接的应用程序在同一登录会话中运行的应用程序可见。 (若要防止调用 WNetGetConnection 失败,应用程序不足以在创建连接的用户帐户中运行。

Windows Server 2003 和 Windows XP:此函数查询与登录会话关联的 MS-DOS 设备命名空间,因为身份验证 ID 会标识 MS-DOS 设备。 (AuthenticationID 是与登录会话关联的 本地唯一标识符或 LUID。这可能会影响调用其中一个 WNet 函数的应用程序,以便在一个用户登录下创建网络驱动器号,但在其他用户登录下查询现有网络驱动器号。 例如,在登录会话中创建用户的第二次登录时,例如,通过调用 CreateProcessAsUser 函数,第二次登录运行调用 GetLogicalDrives 函数的应用程序。 GetLogicalDrives 不会返回由 WNet 函数在第一次登录下创建的网络驱动器号。 请注意,在前面的示例中,第一个登录会话仍然存在,该示例可以应用于任何登录会话,包括终端服务会话。 有关详细信息,请参阅 定义 MS-DOS 设备名称

例子

有关演示如何使用 WNetGetConnection 函数检索与本地设备关联的网络资源的名称的代码示例,请参阅 检索连接名称

注意

winnetwk.h 标头将 WNetGetConnection 定义为一个别名,该别名根据 UNICODE 预处理器常量的定义自动选择此函数的 ANSI 或 Unicode 版本。 将中性编码别名与不中性编码的代码混合使用可能会导致编译或运行时错误不匹配。 有关详细信息,请参阅函数原型的 约定。

要求

要求 价值
最低支持的客户端 Windows 2000 Professional [仅限桌面应用]
支持的最低服务器 Windows 2000 Server [仅限桌面应用]
目标平台 窗户
标头 winnetwk.h
Mpr.lib
DLL Mpr.dll

另请参阅

WNetAddConnection2

WNetAddConnection3

WNetGetUser

Windows 网络(WNet)概述

Windows 网络函数