ホーム › NetworkManagement.NetManagement › NetServerSetInfo
NetServerSetInfo
関数指定したサーバーの構成情報を設定する。
シグネチャ
// NETAPI32.dll
#include <windows.h>
DWORD NetServerSetInfo(
LPWSTR servername, // optional
DWORD level,
BYTE* buf,
DWORD* ParmError // optional
);パラメーター
| 名前 | 型 | 方向 |
|---|---|---|
| servername | LPWSTR | inoptional |
| level | DWORD | in |
| buf | BYTE* | in |
| ParmError | DWORD* | outoptional |
戻り値の型: DWORD
各言語での呼び出し定義
// NETAPI32.dll
#include <windows.h>
DWORD NetServerSetInfo(
LPWSTR servername, // optional
DWORD level,
BYTE* buf,
DWORD* ParmError // optional
);[DllImport("NETAPI32.dll", ExactSpelling = true)]
static extern uint NetServerSetInfo(
[MarshalAs(UnmanagedType.LPWStr)] string servername, // LPWSTR optional
uint level, // DWORD
IntPtr buf, // BYTE*
IntPtr ParmError // DWORD* optional, out
);<DllImport("NETAPI32.dll", ExactSpelling:=True)>
Public Shared Function NetServerSetInfo(
<MarshalAs(UnmanagedType.LPWStr)> servername As String, ' LPWSTR optional
level As UInteger, ' DWORD
buf As IntPtr, ' BYTE*
ParmError As IntPtr ' DWORD* optional, out
) As UInteger
End Function' servername : LPWSTR optional
' level : DWORD
' buf : BYTE*
' ParmError : DWORD* optional, out
Declare PtrSafe Function NetServerSetInfo Lib "netapi32" ( _
ByVal servername As LongPtr, _
ByVal level As Long, _
ByVal buf As LongPtr, _
ByVal ParmError As LongPtr) As Long
' VBA7前提(PtrSafe)。32bit Office では LongPtr→Long。Integer=16bit / Long=32bit / LongLong=64bit。import ctypes
from ctypes import wintypes
NetServerSetInfo = ctypes.windll.netapi32.NetServerSetInfo
NetServerSetInfo.restype = wintypes.DWORD
NetServerSetInfo.argtypes = [
wintypes.LPCWSTR, # servername : LPWSTR optional
wintypes.DWORD, # level : DWORD
ctypes.POINTER(ctypes.c_ubyte), # buf : BYTE*
ctypes.POINTER(wintypes.DWORD), # ParmError : DWORD* optional, out
]require 'fiddle'
require 'fiddle/import'
lib = Fiddle.dlopen('NETAPI32.dll')
NetServerSetInfo = Fiddle::Function.new(
lib['NetServerSetInfo'],
[
Fiddle::TYPE_VOIDP, # servername : LPWSTR optional
-Fiddle::TYPE_INT, # level : DWORD
Fiddle::TYPE_VOIDP, # buf : BYTE*
Fiddle::TYPE_VOIDP, # ParmError : DWORD* optional, out
],
-Fiddle::TYPE_INT)#[link(name = "netapi32")]
extern "system" {
fn NetServerSetInfo(
servername: *mut u16, // LPWSTR optional
level: u32, // DWORD
buf: *mut u8, // BYTE*
ParmError: *mut u32 // DWORD* optional, out
) -> u32;
}
// crates: windows-sys provides ready-made bindings for this API.$sig = @"
[DllImport("NETAPI32.dll")]
public static extern uint NetServerSetInfo([MarshalAs(UnmanagedType.LPWStr)] string servername, uint level, IntPtr buf, IntPtr ParmError);
"@
$api = Add-Type -MemberDefinition $sig -Name 'NETAPI32_NetServerSetInfo' -Namespace Win32 -PassThru
# $api::NetServerSetInfo(servername, level, buf, ParmError)#uselib "NETAPI32.dll"
#func global NetServerSetInfo "NetServerSetInfo" sptr, sptr, sptr, sptr
; NetServerSetInfo servername, level, varptr(buf), varptr(ParmError) ; 戻り値は stat
; servername : LPWSTR optional -> "sptr"
; level : DWORD -> "sptr"
; buf : BYTE* -> "sptr"
; ParmError : DWORD* optional, out -> "sptr"
; ※HSP3.7は #func のため戻り値はシステム変数 stat に格納されます。出力引数:
#uselib "NETAPI32.dll" #cfunc global NetServerSetInfo "NetServerSetInfo" wstr, int, var, var ; res = NetServerSetInfo(servername, level, buf, ParmError) ; servername : LPWSTR optional -> "wstr" ; level : DWORD -> "int" ; buf : BYTE* -> "var" ; ParmError : DWORD* optional, out -> "var" ; ※出力/バッファ引数は var 方式(変数を直接渡す)。varptr 方式にも切替可。#uselib "NETAPI32.dll" #cfunc global NetServerSetInfo "NetServerSetInfo" wstr, int, sptr, sptr ; res = NetServerSetInfo(servername, level, varptr(buf), varptr(ParmError)) ; servername : LPWSTR optional -> "wstr" ; level : DWORD -> "int" ; buf : BYTE* -> "sptr" ; ParmError : DWORD* optional, out -> "sptr" ; ※出力/バッファ引数はポインタ方式(token=sptr / 呼び出しは varptr(変数))。
出力引数:
; DWORD NetServerSetInfo(LPWSTR servername, DWORD level, BYTE* buf, DWORD* ParmError) #uselib "NETAPI32.dll" #cfunc global NetServerSetInfo "NetServerSetInfo" wstr, int, var, var ; res = NetServerSetInfo(servername, level, buf, ParmError) ; servername : LPWSTR optional -> "wstr" ; level : DWORD -> "int" ; buf : BYTE* -> "var" ; ParmError : DWORD* optional, out -> "var" ; ※出力/バッファ引数は var 方式(変数を直接渡す)。varptr 方式にも切替可。; DWORD NetServerSetInfo(LPWSTR servername, DWORD level, BYTE* buf, DWORD* ParmError) #uselib "NETAPI32.dll" #cfunc global NetServerSetInfo "NetServerSetInfo" wstr, int, intptr, intptr ; res = NetServerSetInfo(servername, level, varptr(buf), varptr(ParmError)) ; servername : LPWSTR optional -> "wstr" ; level : DWORD -> "int" ; buf : BYTE* -> "intptr" ; ParmError : DWORD* optional, out -> "intptr" ; ※出力/バッファ引数はポインタ方式(token=intptr / 呼び出しは varptr(変数))。
import (
"golang.org/x/sys/windows"
"unsafe"
)
var (
netapi32 = windows.NewLazySystemDLL("NETAPI32.dll")
procNetServerSetInfo = netapi32.NewProc("NetServerSetInfo")
)
// servername (LPWSTR optional), level (DWORD), buf (BYTE*), ParmError (DWORD* optional, out)
r1, _, err := procNetServerSetInfo.Call(
uintptr(unsafe.Pointer(windows.StringToUTF16Ptr(servername))),
uintptr(level),
uintptr(buf),
uintptr(ParmError),
)
_ = err // syscall.Errno (valid when the call sets last-error)
_ = r1 // DWORDfunction NetServerSetInfo(
servername: PWideChar; // LPWSTR optional
level: DWORD; // DWORD
buf: Pointer; // BYTE*
ParmError: Pointer // DWORD* optional, out
): DWORD; stdcall;
external 'NETAPI32.dll' name 'NetServerSetInfo';result := DllCall("NETAPI32\NetServerSetInfo"
, "WStr", servername ; LPWSTR optional
, "UInt", level ; DWORD
, "Ptr", buf ; BYTE*
, "Ptr", ParmError ; DWORD* optional, out
, "UInt") ; return: DWORD●NetServerSetInfo(servername, level, buf, ParmError) = DLL("NETAPI32.dll", "dword NetServerSetInfo(char*, dword, void*, void*)")
# 呼び出し: NetServerSetInfo(servername, level, buf, ParmError)
# servername : LPWSTR optional -> "char*"
# level : DWORD -> "dword"
# buf : BYTE* -> "void*"
# ParmError : DWORD* optional, out -> "void*"
# なでしこ1は32bit・ANSI(Shift_JIS)。文字列=char*(ANSI)、ポインタ/ハンドル=void*(4byte)。