OpenServiceA 関数 (winsvc.h)

既存のサービスを開きます。

構文

SC_HANDLE OpenServiceA(
  [in] SC_HANDLE hSCManager,
  [in] LPCSTR    lpServiceName,
  [in] DWORD     dwDesiredAccess
);

パラメーター

[in] hSCManager

サービス コントロール マネージャー データベースへのハンドル。 OpenSCManager 関数は、このハンドルを返します。 詳細については、「 サービス セキュリティとアクセス権」を参照してください。

[in] lpServiceName

開くサービスの名前。 これは、サービスを識別するためにユーザー インターフェイス アプリケーションによって表示されるサービス表示名ではなく、サービス オブジェクトの作成時に CreateService 関数の lpServiceName パラメーターで指定された名前です。

文字列の最大長は 256 文字です。 サービス 制御マネージャー データベースでは文字の大文字と小文字が保持されますが、サービス名の比較では常に大文字と小文字が区別されません。 スラッシュ (/) と円記号 (\) は無効なサービス名文字です。

[in] dwDesiredAccess

サービスへのアクセス。 アクセス権の一覧については、「 サービス セキュリティとアクセス権」を参照してください。

要求されたアクセスを許可する前に、システムは呼び出しプロセスのアクセス トークンを、サービス オブジェクトに関連付けられているセキュリティ記述子の随意アクセス制御リストと照合します。

戻り値

関数が成功した場合、戻り値はサービスへのハンドルです。

関数が失敗した場合は、返される値は NULL です。 詳細なエラー情報を得るには、GetLastError を呼び出します。

次のエラー コードは、サービス コントロール マネージャーによって設定できます。 その他は、サービス コントロール マネージャーによって呼び出されるレジストリ関数によって設定できます。

リターン コード 説明
ERROR_ACCESS_DENIED
ハンドルはサービスにアクセスできません。
ERROR_INVALID_HANDLE
指定されたハンドルが無効です。
ERROR_INVALID_NAME
指定されたサービス名が無効です。
ERROR_SERVICE_DOES_NOT_EXIST
指定されたサービスは存在しません。

注釈

返されるハンドルは、 OpenService を呼び出したプロセスに対してのみ有効です。 CloseServiceHandle 関数を呼び出すことで閉じることができます。

OpenService を使用するには、SC_MANAGER_CONNECT以外の特権は必要ありません。

例については、「 サービスの開始」を参照してください。

注意

winsvc.h ヘッダーは、OpenService をエイリアスとして定義します。このエイリアスは、UNICODE プリプロセッサ定数の定義に基づいて、この関数の ANSI または Unicode バージョンを自動的に選択します。 encoding-neutral エイリアスの使用を encoding-neutral ではないコードと混在すると、コンパイル エラーまたはランタイム エラーが発生する不一致が発生する可能性があります。 詳細については、「 関数プロトタイプの規則」を参照してください。

要件

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

こちらもご覧ください

ChangeServiceConfig

CloseServiceHandle

ControlService

CreateService

DeleteService

EnumDependentServices

OpenSCManager

QueryServiceConfig

QueryServiceDynamicInformation

QueryServiceObjectSecurity

QueryServiceStatusEx

SCM ハンドル

サービス関数

SetServiceObjectSecurity

StartService