次の方法で共有


NetShareDel 関数 (lmshare.h)

サーバーの共有リソースの一覧から共有名を削除し、共有リソースへのすべての接続を切断します。

拡張関数 NetShareDelEx を使用すると、呼び出し元は 、SHARE_INFO_0SHARE_INFO_1、SHARE_INFO_2SHARE_INFO_502、または SHARE_INFO_503構造体 指定できます。

構文

NET_API_STATUS NET_API_FUNCTION NetShareDel(
  [in] LMSTR servername,
  [in] LMSTR netname,
       DWORD reserved
);

パラメーター

[in] servername

関数を実行するリモート サーバーの DNS または NetBIOS 名を指定する文字列へのポインター。 このパラメーターが NULL の場合は、ローカル コンピューターが使用されます。

_WIN32_WINNTまたはFORCE_UNICODEが定義されている場合、この文字列は Unicode です。

[in] netname

削除する共有の名前を指定する文字列へのポインター。

_WIN32_WINNTまたはFORCE_UNICODEが定義されている場合、この文字列は Unicode です。

reserved

予約済み。0 である必要があります。

戻り値

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

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

リターン コード 説明
ERROR_ACCESS_DENIED
ユーザーには、要求された情報へのアクセス権がありません。
ERROR_INVALID_PARAMETER
指定されたパラメーターが無効です。
ERROR_NOT_ENOUGH_MEMORY
メモリ不足です。
NERR_NetNameNotFound
共有名が存在しません。

解説

この関数は、サーバー メッセージ ブロック (SMB) 共有にのみ適用されます。 分散ファイル システム (DFS) や WebDAV 共有などの他の種類の共有では、すべての種類の共有をサポートする Windows ネットワーク (WNet) 関数を使用します。

管理者、サーバー オペレーター、または Power Users ローカル グループのメンバー、またはサーバー オペレーター グループ メンバーシップを持つメンバーのみが、 NetShareDel 関数の呼び出しでファイル共有を正常に削除できます。 印刷オペレーターは、プリンター共有を削除できます。

Active Directory のプログラミングを行っている場合は、特定の Active Directory サービス インターフェイス (ADSI) メソッドを呼び出して、ネットワーク管理共有関数を呼び出すことで実現できるのと同じ機能を実現できる場合があります。 詳細については、「 IADsFileShare」を参照してください。

次のコード サンプルは、 NetShareDel 関数の呼び出しを使用して共有を削除する方法を示しています。

#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;

   if(argc<3)
      printf("Usage: NetShareDel server share\n");
   else
   {
      //
      // Call the NetShareDel function to delete the share.
      //
      res=NetShareDel(argv[1], argv[2], 0);
      //
      // Display the result of the call.
      //
      if(res==0)
         printf("Share Removed.\n");
      else
         printf("Error: %u\n", res);
   }
   return;
}

要件

   
サポートされている最小のクライアント Windows XP (デスクトップ アプリのみ)
サポートされている最小のサーバー Windows Server 2003 (デスクトップ アプリのみ)
対象プラットフォーム Windows
ヘッダー lmshare.h (include Lm.h)
Library Netapi32.lib
[DLL] Netapi32.dll

関連項目

NetShareAdd

NetShareDelEx

ネットワーク管理機能

ネットワーク管理の概要

ネットワーク共有関数