OpenServiceW 関数 (winsvc.h)
既存のサービスを開きます。
構文
SC_HANDLE OpenServiceW(
[in] SC_HANDLE hSCManager,
[in] LPCWSTR lpServiceName,
[in] DWORD dwDesiredAccess
);
パラメーター
[in] hSCManager
サービス コントロール マネージャー データベースへのハンドル。 OpenSCManager 関数は、このハンドルを返します。 詳細については、「 サービス セキュリティとアクセス権」を参照してください。
[in] lpServiceName
開くサービスの名前。 これは、サービスを識別するためにユーザー インターフェイス アプリケーションによって表示されるサービス表示名ではなく、サービス オブジェクトの作成時に CreateService 関数の lpServiceName パラメーターで指定された名前です。
文字列の最大長は 256 文字です。 サービス 制御マネージャー データベースでは文字の大文字と小文字が保持されますが、サービス名の比較では常に大文字と小文字が区別されません。 スラッシュ (/) と円記号 (\) は無効なサービス名文字です。
[in] dwDesiredAccess
サービスへのアクセス。 アクセス権の一覧については、「 サービス セキュリティとアクセス権」を参照してください。
要求されたアクセス権を付与する前に、システムは、呼び出し元プロセスのアクセス トークンを、サービス オブジェクトに関連付けられているセキュリティ記述子の随意アクセス制御リストと照合します。
戻り値
関数が成功した場合、戻り値はサービスへのハンドルです。
関数が失敗した場合は、返される値は NULL です。 詳細なエラー情報を得るには、GetLastError を呼び出します。
サービス コントロール マネージャーでは、次のエラー コードを設定できます。 その他は、サービス コントロール マネージャーによって呼び出されるレジストリ関数によって設定できます。
リターン コード | 説明 |
---|---|
|
ハンドルはサービスにアクセスできません。 |
|
指定されたハンドルが無効です。 |
|
指定されたサービス名が無効です。 |
|
指定されたサービスは存在しません。 |
注釈
返されるハンドルは、 OpenService を呼び出したプロセスに対してのみ有効です。 CloseServiceHandle 関数を呼び出すことで閉じることができます。
OpenService を使用するには、SC_MANAGER_CONNECT以外の特権は必要ありません。
例
例については、「 サービスの開始」を参照してください。
注意
winsvc.h ヘッダーは、OpenService をエイリアスとして定義します。このエイリアスは、UNICODE プリプロセッサ定数の定義に基づいて、この関数の ANSI または Unicode バージョンを自動的に選択します。 エンコードに依存しないエイリアスをエンコードニュートラルでないコードと組み合わせて使用すると、コンパイルまたはランタイム エラーが発生する不一致が発生する可能性があります。 詳細については、「 関数プロトタイプの規則」を参照してください。
要件
要件 | 値 |
---|---|
サポートされている最小のクライアント | Windows XP (デスクトップ アプリのみ) |
サポートされている最小のサーバー | Windows Server 2003 (デスクトップ アプリのみ) |
対象プラットフォーム | Windows |
ヘッダー | winsvc.h (Windows.h を含む) |
Library | Advapi32.lib |
[DLL] | Advapi32.dll |