NetShareDel 関数 (lmshare.h)
サーバーの共有リソースの一覧から共有名を削除し、共有リソースへのすべての接続を切断します。
拡張関数 NetShareDelEx を使用すると、呼び出し元は 、SHARE_INFO_0、 SHARE_INFO_1、SHARE_INFO_2、 SHARE_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。
関数が失敗した場合、戻り値には次のいずれかのエラー コードを指定できます。
リターン コード | 説明 |
---|---|
|
ユーザーには、要求された情報へのアクセス権がありません。 |
|
指定されたパラメーターが無効です。 |
|
メモリ不足です。 |
|
共有名が存在しません。 |
解説
この関数は、サーバー メッセージ ブロック (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 |