ホーム › Security.Cryptography › CryptProtectData
CryptProtectData
関数現在のユーザーまたは機械のコンテキストでデータを暗号化保護する。
シグネチャ
// CRYPT32.dll
#include <windows.h>
BOOL CryptProtectData(
CRYPT_INTEGER_BLOB* pDataIn,
LPCWSTR szDataDescr, // optional
CRYPT_INTEGER_BLOB* pOptionalEntropy, // optional
void* pvReserved, // optional
CRYPTPROTECT_PROMPTSTRUCT* pPromptStruct, // optional
DWORD dwFlags,
CRYPT_INTEGER_BLOB* pDataOut
);パラメーター
| 名前 | 型 | 方向 |
|---|---|---|
| pDataIn | CRYPT_INTEGER_BLOB* | in |
| szDataDescr | LPCWSTR | inoptional |
| pOptionalEntropy | CRYPT_INTEGER_BLOB* | inoptional |
| pvReserved | void* | optional |
| pPromptStruct | CRYPTPROTECT_PROMPTSTRUCT* | inoptional |
| dwFlags | DWORD | in |
| pDataOut | CRYPT_INTEGER_BLOB* | out |
戻り値の型: BOOL
各言語での呼び出し定義
// CRYPT32.dll
#include <windows.h>
BOOL CryptProtectData(
CRYPT_INTEGER_BLOB* pDataIn,
LPCWSTR szDataDescr, // optional
CRYPT_INTEGER_BLOB* pOptionalEntropy, // optional
void* pvReserved, // optional
CRYPTPROTECT_PROMPTSTRUCT* pPromptStruct, // optional
DWORD dwFlags,
CRYPT_INTEGER_BLOB* pDataOut
);[return: MarshalAs(UnmanagedType.Bool)]
[DllImport("CRYPT32.dll", SetLastError = true, ExactSpelling = true)]
static extern bool CryptProtectData(
IntPtr pDataIn, // CRYPT_INTEGER_BLOB*
[MarshalAs(UnmanagedType.LPWStr)] string szDataDescr, // LPCWSTR optional
IntPtr pOptionalEntropy, // CRYPT_INTEGER_BLOB* optional
IntPtr pvReserved, // void* optional
IntPtr pPromptStruct, // CRYPTPROTECT_PROMPTSTRUCT* optional
uint dwFlags, // DWORD
IntPtr pDataOut // CRYPT_INTEGER_BLOB* out
);<DllImport("CRYPT32.dll", SetLastError:=True, ExactSpelling:=True)>
Public Shared Function CryptProtectData(
pDataIn As IntPtr, ' CRYPT_INTEGER_BLOB*
<MarshalAs(UnmanagedType.LPWStr)> szDataDescr As String, ' LPCWSTR optional
pOptionalEntropy As IntPtr, ' CRYPT_INTEGER_BLOB* optional
pvReserved As IntPtr, ' void* optional
pPromptStruct As IntPtr, ' CRYPTPROTECT_PROMPTSTRUCT* optional
dwFlags As UInteger, ' DWORD
pDataOut As IntPtr ' CRYPT_INTEGER_BLOB* out
) As Boolean
End Function' pDataIn : CRYPT_INTEGER_BLOB*
' szDataDescr : LPCWSTR optional
' pOptionalEntropy : CRYPT_INTEGER_BLOB* optional
' pvReserved : void* optional
' pPromptStruct : CRYPTPROTECT_PROMPTSTRUCT* optional
' dwFlags : DWORD
' pDataOut : CRYPT_INTEGER_BLOB* out
Declare PtrSafe Function CryptProtectData Lib "crypt32" ( _
ByVal pDataIn As LongPtr, _
ByVal szDataDescr As LongPtr, _
ByVal pOptionalEntropy As LongPtr, _
ByVal pvReserved As LongPtr, _
ByVal pPromptStruct As LongPtr, _
ByVal dwFlags As Long, _
ByVal pDataOut As LongPtr) As Long
' VBA7前提(PtrSafe)。32bit Office では LongPtr→Long。Integer=16bit / Long=32bit / LongLong=64bit。import ctypes
from ctypes import wintypes
CryptProtectData = ctypes.windll.crypt32.CryptProtectData
CryptProtectData.restype = wintypes.BOOL
CryptProtectData.argtypes = [
ctypes.c_void_p, # pDataIn : CRYPT_INTEGER_BLOB*
wintypes.LPCWSTR, # szDataDescr : LPCWSTR optional
ctypes.c_void_p, # pOptionalEntropy : CRYPT_INTEGER_BLOB* optional
ctypes.POINTER(None), # pvReserved : void* optional
ctypes.c_void_p, # pPromptStruct : CRYPTPROTECT_PROMPTSTRUCT* optional
wintypes.DWORD, # dwFlags : DWORD
ctypes.c_void_p, # pDataOut : CRYPT_INTEGER_BLOB* out
]
# GetLastError: use ctypes.GetLastError() (or ctypes.WinDLL(use_last_error=True))require 'fiddle'
require 'fiddle/import'
lib = Fiddle.dlopen('CRYPT32.dll')
CryptProtectData = Fiddle::Function.new(
lib['CryptProtectData'],
[
Fiddle::TYPE_VOIDP, # pDataIn : CRYPT_INTEGER_BLOB*
Fiddle::TYPE_VOIDP, # szDataDescr : LPCWSTR optional
Fiddle::TYPE_VOIDP, # pOptionalEntropy : CRYPT_INTEGER_BLOB* optional
Fiddle::TYPE_VOIDP, # pvReserved : void* optional
Fiddle::TYPE_VOIDP, # pPromptStruct : CRYPTPROTECT_PROMPTSTRUCT* optional
-Fiddle::TYPE_INT, # dwFlags : DWORD
Fiddle::TYPE_VOIDP, # pDataOut : CRYPT_INTEGER_BLOB* out
],
Fiddle::TYPE_INT)#[link(name = "crypt32")]
extern "system" {
fn CryptProtectData(
pDataIn: *mut CRYPT_INTEGER_BLOB, // CRYPT_INTEGER_BLOB*
szDataDescr: *const u16, // LPCWSTR optional
pOptionalEntropy: *mut CRYPT_INTEGER_BLOB, // CRYPT_INTEGER_BLOB* optional
pvReserved: *mut (), // void* optional
pPromptStruct: *mut CRYPTPROTECT_PROMPTSTRUCT, // CRYPTPROTECT_PROMPTSTRUCT* optional
dwFlags: u32, // DWORD
pDataOut: *mut CRYPT_INTEGER_BLOB // CRYPT_INTEGER_BLOB* out
) -> i32;
}
// crates: windows-sys provides ready-made bindings for this API.$sig = @"
[return: MarshalAs(UnmanagedType.Bool)]
[DllImport("CRYPT32.dll", SetLastError = true)]
public static extern bool CryptProtectData(IntPtr pDataIn, [MarshalAs(UnmanagedType.LPWStr)] string szDataDescr, IntPtr pOptionalEntropy, IntPtr pvReserved, IntPtr pPromptStruct, uint dwFlags, IntPtr pDataOut);
"@
$api = Add-Type -MemberDefinition $sig -Name 'CRYPT32_CryptProtectData' -Namespace Win32 -PassThru
# $api::CryptProtectData(pDataIn, szDataDescr, pOptionalEntropy, pvReserved, pPromptStruct, dwFlags, pDataOut)#uselib "CRYPT32.dll"
#func global CryptProtectData "CryptProtectData" sptr, sptr, sptr, sptr, sptr, sptr, sptr
; CryptProtectData varptr(pDataIn), szDataDescr, varptr(pOptionalEntropy), pvReserved, varptr(pPromptStruct), dwFlags, varptr(pDataOut) ; 戻り値は stat
; pDataIn : CRYPT_INTEGER_BLOB* -> "sptr"
; szDataDescr : LPCWSTR optional -> "sptr"
; pOptionalEntropy : CRYPT_INTEGER_BLOB* optional -> "sptr"
; pvReserved : void* optional -> "sptr"
; pPromptStruct : CRYPTPROTECT_PROMPTSTRUCT* optional -> "sptr"
; dwFlags : DWORD -> "sptr"
; pDataOut : CRYPT_INTEGER_BLOB* out -> "sptr"
; ※HSP3.7は #func のため戻り値はシステム変数 stat に格納されます。出力引数:
#uselib "CRYPT32.dll" #cfunc global CryptProtectData "CryptProtectData" var, wstr, var, sptr, var, int, var ; res = CryptProtectData(pDataIn, szDataDescr, pOptionalEntropy, pvReserved, pPromptStruct, dwFlags, pDataOut) ; pDataIn : CRYPT_INTEGER_BLOB* -> "var" ; szDataDescr : LPCWSTR optional -> "wstr" ; pOptionalEntropy : CRYPT_INTEGER_BLOB* optional -> "var" ; pvReserved : void* optional -> "sptr" ; pPromptStruct : CRYPTPROTECT_PROMPTSTRUCT* optional -> "var" ; dwFlags : DWORD -> "int" ; pDataOut : CRYPT_INTEGER_BLOB* out -> "var" ; ※出力/バッファ引数は var 方式(変数を直接渡す)。varptr 方式にも切替可。#uselib "CRYPT32.dll" #cfunc global CryptProtectData "CryptProtectData" sptr, wstr, sptr, sptr, sptr, int, sptr ; res = CryptProtectData(varptr(pDataIn), szDataDescr, varptr(pOptionalEntropy), pvReserved, varptr(pPromptStruct), dwFlags, varptr(pDataOut)) ; pDataIn : CRYPT_INTEGER_BLOB* -> "sptr" ; szDataDescr : LPCWSTR optional -> "wstr" ; pOptionalEntropy : CRYPT_INTEGER_BLOB* optional -> "sptr" ; pvReserved : void* optional -> "sptr" ; pPromptStruct : CRYPTPROTECT_PROMPTSTRUCT* optional -> "sptr" ; dwFlags : DWORD -> "int" ; pDataOut : CRYPT_INTEGER_BLOB* out -> "sptr" ; ※出力/バッファ引数はポインタ方式(token=sptr / 呼び出しは varptr(変数))。
出力引数:
; BOOL CryptProtectData(CRYPT_INTEGER_BLOB* pDataIn, LPCWSTR szDataDescr, CRYPT_INTEGER_BLOB* pOptionalEntropy, void* pvReserved, CRYPTPROTECT_PROMPTSTRUCT* pPromptStruct, DWORD dwFlags, CRYPT_INTEGER_BLOB* pDataOut) #uselib "CRYPT32.dll" #cfunc global CryptProtectData "CryptProtectData" var, wstr, var, intptr, var, int, var ; res = CryptProtectData(pDataIn, szDataDescr, pOptionalEntropy, pvReserved, pPromptStruct, dwFlags, pDataOut) ; pDataIn : CRYPT_INTEGER_BLOB* -> "var" ; szDataDescr : LPCWSTR optional -> "wstr" ; pOptionalEntropy : CRYPT_INTEGER_BLOB* optional -> "var" ; pvReserved : void* optional -> "intptr" ; pPromptStruct : CRYPTPROTECT_PROMPTSTRUCT* optional -> "var" ; dwFlags : DWORD -> "int" ; pDataOut : CRYPT_INTEGER_BLOB* out -> "var" ; ※出力/バッファ引数は var 方式(変数を直接渡す)。varptr 方式にも切替可。; BOOL CryptProtectData(CRYPT_INTEGER_BLOB* pDataIn, LPCWSTR szDataDescr, CRYPT_INTEGER_BLOB* pOptionalEntropy, void* pvReserved, CRYPTPROTECT_PROMPTSTRUCT* pPromptStruct, DWORD dwFlags, CRYPT_INTEGER_BLOB* pDataOut) #uselib "CRYPT32.dll" #cfunc global CryptProtectData "CryptProtectData" intptr, wstr, intptr, intptr, intptr, int, intptr ; res = CryptProtectData(varptr(pDataIn), szDataDescr, varptr(pOptionalEntropy), pvReserved, varptr(pPromptStruct), dwFlags, varptr(pDataOut)) ; pDataIn : CRYPT_INTEGER_BLOB* -> "intptr" ; szDataDescr : LPCWSTR optional -> "wstr" ; pOptionalEntropy : CRYPT_INTEGER_BLOB* optional -> "intptr" ; pvReserved : void* optional -> "intptr" ; pPromptStruct : CRYPTPROTECT_PROMPTSTRUCT* optional -> "intptr" ; dwFlags : DWORD -> "int" ; pDataOut : CRYPT_INTEGER_BLOB* out -> "intptr" ; ※出力/バッファ引数はポインタ方式(token=intptr / 呼び出しは varptr(変数))。
import (
"golang.org/x/sys/windows"
"unsafe"
)
var (
crypt32 = windows.NewLazySystemDLL("CRYPT32.dll")
procCryptProtectData = crypt32.NewProc("CryptProtectData")
)
// pDataIn (CRYPT_INTEGER_BLOB*), szDataDescr (LPCWSTR optional), pOptionalEntropy (CRYPT_INTEGER_BLOB* optional), pvReserved (void* optional), pPromptStruct (CRYPTPROTECT_PROMPTSTRUCT* optional), dwFlags (DWORD), pDataOut (CRYPT_INTEGER_BLOB* out)
r1, _, err := procCryptProtectData.Call(
uintptr(pDataIn),
uintptr(unsafe.Pointer(windows.StringToUTF16Ptr(szDataDescr))),
uintptr(pOptionalEntropy),
uintptr(pvReserved),
uintptr(pPromptStruct),
uintptr(dwFlags),
uintptr(pDataOut),
)
_ = err // syscall.Errno (valid when the call sets last-error)
_ = r1 // BOOLfunction CryptProtectData(
pDataIn: Pointer; // CRYPT_INTEGER_BLOB*
szDataDescr: PWideChar; // LPCWSTR optional
pOptionalEntropy: Pointer; // CRYPT_INTEGER_BLOB* optional
pvReserved: Pointer; // void* optional
pPromptStruct: Pointer; // CRYPTPROTECT_PROMPTSTRUCT* optional
dwFlags: DWORD; // DWORD
pDataOut: Pointer // CRYPT_INTEGER_BLOB* out
): BOOL; stdcall;
external 'CRYPT32.dll' name 'CryptProtectData';result := DllCall("CRYPT32\CryptProtectData"
, "Ptr", pDataIn ; CRYPT_INTEGER_BLOB*
, "WStr", szDataDescr ; LPCWSTR optional
, "Ptr", pOptionalEntropy ; CRYPT_INTEGER_BLOB* optional
, "Ptr", pvReserved ; void* optional
, "Ptr", pPromptStruct ; CRYPTPROTECT_PROMPTSTRUCT* optional
, "UInt", dwFlags ; DWORD
, "Ptr", pDataOut ; CRYPT_INTEGER_BLOB* out
, "Int") ; return: BOOL●CryptProtectData(pDataIn, szDataDescr, pOptionalEntropy, pvReserved, pPromptStruct, dwFlags, pDataOut) = DLL("CRYPT32.dll", "bool CryptProtectData(void*, char*, void*, void*, void*, dword, void*)")
# 呼び出し: CryptProtectData(pDataIn, szDataDescr, pOptionalEntropy, pvReserved, pPromptStruct, dwFlags, pDataOut)
# pDataIn : CRYPT_INTEGER_BLOB* -> "void*"
# szDataDescr : LPCWSTR optional -> "char*"
# pOptionalEntropy : CRYPT_INTEGER_BLOB* optional -> "void*"
# pvReserved : void* optional -> "void*"
# pPromptStruct : CRYPTPROTECT_PROMPTSTRUCT* optional -> "void*"
# dwFlags : DWORD -> "dword"
# pDataOut : CRYPT_INTEGER_BLOB* out -> "void*"
# なでしこ1は32bit・ANSI(Shift_JIS)。文字列=char*(ANSI)、ポインタ/ハンドル=void*(4byte)。