Win32 API 日本語リファレンス
ホームNetworkManagement.NetManagement › NetServiceControl

NetServiceControl

関数
ネットワークサービスに制御コードを送信する。
DLLNETAPI32.dll呼出規約winapi

シグネチャ

// NETAPI32.dll
#include <windows.h>

DWORD NetServiceControl(
    LPCWSTR servername,   // optional
    LPCWSTR service,
    DWORD opcode,
    DWORD arg,
    BYTE** bufptr
);

パラメーター

名前方向
servernameLPCWSTRinoptional
serviceLPCWSTRin
opcodeDWORDin
argDWORDin
bufptrBYTE**out

戻り値の型: DWORD

各言語での呼び出し定義

// NETAPI32.dll
#include <windows.h>

DWORD NetServiceControl(
    LPCWSTR servername,   // optional
    LPCWSTR service,
    DWORD opcode,
    DWORD arg,
    BYTE** bufptr
);
[DllImport("NETAPI32.dll", ExactSpelling = true)]
static extern uint NetServiceControl(
    [MarshalAs(UnmanagedType.LPWStr)] string servername,   // LPCWSTR optional
    [MarshalAs(UnmanagedType.LPWStr)] string service,   // LPCWSTR
    uint opcode,   // DWORD
    uint arg,   // DWORD
    IntPtr bufptr   // BYTE** out
);
<DllImport("NETAPI32.dll", ExactSpelling:=True)>
Public Shared Function NetServiceControl(
    <MarshalAs(UnmanagedType.LPWStr)> servername As String,   ' LPCWSTR optional
    <MarshalAs(UnmanagedType.LPWStr)> service As String,   ' LPCWSTR
    opcode As UInteger,   ' DWORD
    arg As UInteger,   ' DWORD
    bufptr As IntPtr   ' BYTE** out
) As UInteger
End Function
' servername : LPCWSTR optional
' service : LPCWSTR
' opcode : DWORD
' arg : DWORD
' bufptr : BYTE** out
Declare PtrSafe Function NetServiceControl Lib "netapi32" ( _
    ByVal servername As LongPtr, _
    ByVal service As LongPtr, _
    ByVal opcode As Long, _
    ByVal arg As Long, _
    ByVal bufptr As LongPtr) As Long
' VBA7前提(PtrSafe)。32bit Office では LongPtr→Long。Integer=16bit / Long=32bit / LongLong=64bit。
import ctypes
from ctypes import wintypes

NetServiceControl = ctypes.windll.netapi32.NetServiceControl
NetServiceControl.restype = wintypes.DWORD
NetServiceControl.argtypes = [
    wintypes.LPCWSTR,  # servername : LPCWSTR optional
    wintypes.LPCWSTR,  # service : LPCWSTR
    wintypes.DWORD,  # opcode : DWORD
    wintypes.DWORD,  # arg : DWORD
    ctypes.c_void_p,  # bufptr : BYTE** out
]
require 'fiddle'
require 'fiddle/import'

lib = Fiddle.dlopen('NETAPI32.dll')
NetServiceControl = Fiddle::Function.new(
  lib['NetServiceControl'],
  [
    Fiddle::TYPE_VOIDP,  # servername : LPCWSTR optional
    Fiddle::TYPE_VOIDP,  # service : LPCWSTR
    -Fiddle::TYPE_INT,  # opcode : DWORD
    -Fiddle::TYPE_INT,  # arg : DWORD
    Fiddle::TYPE_VOIDP,  # bufptr : BYTE** out
  ],
  -Fiddle::TYPE_INT)
#[link(name = "netapi32")]
extern "system" {
    fn NetServiceControl(
        servername: *const u16,  // LPCWSTR optional
        service: *const u16,  // LPCWSTR
        opcode: u32,  // DWORD
        arg: u32,  // DWORD
        bufptr: *mut *mut u8  // BYTE** out
    ) -> u32;
}
// crates: windows-sys provides ready-made bindings for this API.
$sig = @"
[DllImport("NETAPI32.dll")]
public static extern uint NetServiceControl([MarshalAs(UnmanagedType.LPWStr)] string servername, [MarshalAs(UnmanagedType.LPWStr)] string service, uint opcode, uint arg, IntPtr bufptr);
"@
$api = Add-Type -MemberDefinition $sig -Name 'NETAPI32_NetServiceControl' -Namespace Win32 -PassThru
# $api::NetServiceControl(servername, service, opcode, arg, bufptr)
#uselib "NETAPI32.dll"
#func global NetServiceControl "NetServiceControl" sptr, sptr, sptr, sptr, sptr
; NetServiceControl servername, service, opcode, arg, varptr(bufptr)   ; 戻り値は stat
; servername : LPCWSTR optional -> "sptr"
; service : LPCWSTR -> "sptr"
; opcode : DWORD -> "sptr"
; arg : DWORD -> "sptr"
; bufptr : BYTE** out -> "sptr"
; ※HSP3.7は #func のため戻り値はシステム変数 stat に格納されます。
出力引数:
#uselib "NETAPI32.dll"
#cfunc global NetServiceControl "NetServiceControl" wstr, wstr, int, int, var
; res = NetServiceControl(servername, service, opcode, arg, bufptr)
; servername : LPCWSTR optional -> "wstr"
; service : LPCWSTR -> "wstr"
; opcode : DWORD -> "int"
; arg : DWORD -> "int"
; bufptr : BYTE** out -> "var"
; ※出力/バッファ引数は var 方式(変数を直接渡す)。varptr 方式にも切替可。
出力引数:
; DWORD NetServiceControl(LPCWSTR servername, LPCWSTR service, DWORD opcode, DWORD arg, BYTE** bufptr)
#uselib "NETAPI32.dll"
#cfunc global NetServiceControl "NetServiceControl" wstr, wstr, int, int, var
; res = NetServiceControl(servername, service, opcode, arg, bufptr)
; servername : LPCWSTR optional -> "wstr"
; service : LPCWSTR -> "wstr"
; opcode : DWORD -> "int"
; arg : DWORD -> "int"
; bufptr : BYTE** out -> "var"
; ※出力/バッファ引数は var 方式(変数を直接渡す)。varptr 方式にも切替可。
import (
	"golang.org/x/sys/windows"
	"unsafe"
)

var (
	netapi32 = windows.NewLazySystemDLL("NETAPI32.dll")
	procNetServiceControl = netapi32.NewProc("NetServiceControl")
)

// servername (LPCWSTR optional), service (LPCWSTR), opcode (DWORD), arg (DWORD), bufptr (BYTE** out)
r1, _, err := procNetServiceControl.Call(
	uintptr(unsafe.Pointer(windows.StringToUTF16Ptr(servername))),
	uintptr(unsafe.Pointer(windows.StringToUTF16Ptr(service))),
	uintptr(opcode),
	uintptr(arg),
	uintptr(bufptr),
)
_ = err  // syscall.Errno (valid when the call sets last-error)
_ = r1   // DWORD
function NetServiceControl(
  servername: PWideChar;   // LPCWSTR optional
  service: PWideChar;   // LPCWSTR
  opcode: DWORD;   // DWORD
  arg: DWORD;   // DWORD
  bufptr: Pointer   // BYTE** out
): DWORD; stdcall;
  external 'NETAPI32.dll' name 'NetServiceControl';
result := DllCall("NETAPI32\NetServiceControl"
    , "WStr", servername   ; LPCWSTR optional
    , "WStr", service   ; LPCWSTR
    , "UInt", opcode   ; DWORD
    , "UInt", arg   ; DWORD
    , "Ptr", bufptr   ; BYTE** out
    , "UInt")   ; return: DWORD
●NetServiceControl(servername, service, opcode, arg, bufptr) = DLL("NETAPI32.dll", "dword NetServiceControl(char*, char*, dword, dword, void*)")
# 呼び出し: NetServiceControl(servername, service, opcode, arg, bufptr)
# servername : LPCWSTR optional -> "char*"
# service : LPCWSTR -> "char*"
# opcode : DWORD -> "dword"
# arg : DWORD -> "dword"
# bufptr : BYTE** out -> "void*"
# なでしこ1は32bit・ANSI(Shift_JIS)。文字列=char*(ANSI)、ポインタ/ハンドル=void*(4byte)。