NetShareCheck 関数 (lmshare.h)
サーバーがデバイスを共有しているかどうかを確認します。
構文
NET_API_STATUS NET_API_FUNCTION NetShareCheck(
[in] LMSTR servername,
[in] LMSTR device,
[out] LPDWORD type
);
パラメーター
[in] servername
関数を実行するリモート サーバーの DNS または NetBIOS 名を指定する文字列へのポインター。 このパラメーターが NULL の場合は、ローカル コンピューターが使用されます。
[in] device
共有アクセス用にチェックするデバイスの名前を指定する文字列へのポインター。
[out] type
共有デバイスの種類を指定するフラグのビットマスクを受け取る変数へのポインター。 このパラメーターは、関数が正常に返された場合にのみ設定されます。
次のいずれかのフラグを指定できます。
値 | 説明 |
---|---|
|
ディスク ドライブ。 |
|
印刷キュー。 |
|
通信デバイス。 |
|
プロセス間通信 (IPC)。 |
さらに、次のフラグの一方または両方を指定できます。
値 | 説明 |
---|---|
|
プロセス間通信 (IPC$) またはサーバーのリモート管理 (ADMIN$) 用に予約された特別な共有。 C$、D$、E$ などの管理共有を参照することもできます。 詳細については、「 ネットワーク共有関数」を参照してください。 |
|
一時的な共有。 |
戻り値
関数が成功した場合、戻り値は NERR_Success。
関数が失敗した場合、戻り値には次のいずれかのエラー コードを指定できます。
リターン コード | 説明 |
---|---|
|
メモリ不足です。 |
|
デバイスが共有されていません。 |
解説
この関数は、サーバー メッセージ ブロック (SMB) 共有にのみ適用されます。 分散ファイル システム (DFS) や WebDAV 共有などの他の種類の共有では、すべての種類の共有をサポートする Windows ネットワーク (WNet) 関数を使用します。
NetShareCheck 関数を正常に実行するために特別なグループ メンバーシップは必要ありません。
Active Directory のプログラミングを行っている場合は、特定の Active Directory サービス インターフェイス (ADSI) メソッドを呼び出して、ネットワーク管理共有関数を呼び出すことで実現できるのと同じ機能を実現できる場合があります。 詳細については、「 IADsFileShare」を参照してください。
例
次のコード サンプルは、NetShareCheck 関数の呼び出しを使用して、サーバーがデバイスを共有しているかどうかをチェックする方法を示しています。 関数は、前述の type パラメーターのドキュメントで説明されているように、共有されているデバイスの 種類 を返します。
#ifndef UNICODE
#define UNICODE
#endif
#include <windows.h>
#include <stdio.h>
#include <lm.h>
#pragma comment(lib, "Netapi32.lib")
void wmain( int argc, TCHAR *argv[ ])
{
NET_API_STATUS res;
DWORD devType = 0;
if(argc<3)
printf("Usage: NetShareCheck server device\n");
else
{
//
// Call the NetShareCheck function.
//
res=NetShareCheck(argv[1], argv[2], &devType);
//
// If the function succeeds, inform the user.
//
if(res==0)
printf("Device is shared as type %u.\n",devType);
//
// Otherwise, print the error.
//
else
printf("Error: %u\n", res);
}
return;
}
要件
サポートされている最小のクライアント | Windows XP (デスクトップ アプリのみ) |
サポートされている最小のサーバー | Windows Server 2003 (デスクトップ アプリのみ) |
対象プラットフォーム | Windows |
ヘッダー | lmshare.h (include Lm.h) |
Library | Netapi32.lib |
[DLL] | Netapi32.dll |