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

共有デバイスの種類を指定するフラグのビットマスクを受け取る変数へのポインター。 このパラメーターは、関数が正常に返された場合にのみ設定されます。

次のいずれかのフラグを指定できます。

説明
STYPE_DISKTREE
ディスク ドライブ。
STYPE_PRINTQ
印刷キュー。
STYPE_DEVICE
通信デバイス。
STYPE_IPC
プロセス間通信 (IPC)。
 

さらに、次のフラグの一方または両方を指定できます。

説明
STYPE_SPECIAL
プロセス間通信 (IPC$) またはサーバーのリモート管理 (ADMIN$) 用に予約された特別な共有。 C$、D$、E$ などの管理共有を参照することもできます。 詳細については、「 ネットワーク共有関数」を参照してください。
STYPE_TEMPORARY
一時的な共有。

戻り値

関数が成功した場合、戻り値は NERR_Success

関数が失敗した場合、戻り値には次のいずれかのエラー コードを指定できます。

リターン コード 説明
ERROR_NOT_ENOUGH_MEMORY
メモリ不足です。
NERR_DeviceNotShared
デバイスが共有されていません。

解説

この関数は、サーバー メッセージ ブロック (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

関連項目

NetShareEnum

NetShareGetInfo

ネットワーク管理機能

ネットワーク管理の概要

ネットワーク共有関数