ホーム › Security.Cryptography.Certificates › PstGetCertificateChain
PstGetCertificateChain
関数指定証明書と信頼発行者から証明書チェーンを構築して取得する。
シグネチャ
// certpoleng.dll
#include <windows.h>
NTSTATUS PstGetCertificateChain(
const CERT_CONTEXT* pCert,
SecPkgContext_IssuerListInfoEx* pTrustedIssuers,
CERT_CHAIN_CONTEXT** ppCertChainContext
);パラメーター
| 名前 | 型 | 方向 | 説明 |
|---|---|---|---|
| pCert | CERT_CONTEXT* | in | チェーンを構築する起点となる証明書のCERT_CONTEXTへのポインタ。 |
| pTrustedIssuers | SecPkgContext_IssuerListInfoEx* | in | 信頼された発行者リストを示す構造体へのポインタ。チェーン構築の基準とする。 |
| ppCertChainContext | CERT_CHAIN_CONTEXT** | out | 構築された証明書チェーンコンテキストへのポインタを受け取る出力ポインタ。 |
戻り値の型: NTSTATUS
各言語での呼び出し定義
// certpoleng.dll
#include <windows.h>
NTSTATUS PstGetCertificateChain(
const CERT_CONTEXT* pCert,
SecPkgContext_IssuerListInfoEx* pTrustedIssuers,
CERT_CHAIN_CONTEXT** ppCertChainContext
);[DllImport("certpoleng.dll", ExactSpelling = true)]
static extern int PstGetCertificateChain(
IntPtr pCert, // CERT_CONTEXT*
IntPtr pTrustedIssuers, // SecPkgContext_IssuerListInfoEx*
IntPtr ppCertChainContext // CERT_CHAIN_CONTEXT** out
);<DllImport("certpoleng.dll", ExactSpelling:=True)>
Public Shared Function PstGetCertificateChain(
pCert As IntPtr, ' CERT_CONTEXT*
pTrustedIssuers As IntPtr, ' SecPkgContext_IssuerListInfoEx*
ppCertChainContext As IntPtr ' CERT_CHAIN_CONTEXT** out
) As Integer
End Function' pCert : CERT_CONTEXT*
' pTrustedIssuers : SecPkgContext_IssuerListInfoEx*
' ppCertChainContext : CERT_CHAIN_CONTEXT** out
Declare PtrSafe Function PstGetCertificateChain Lib "certpoleng" ( _
ByVal pCert As LongPtr, _
ByVal pTrustedIssuers As LongPtr, _
ByVal ppCertChainContext As LongPtr) As Long
' VBA7前提(PtrSafe)。32bit Office では LongPtr→Long。Integer=16bit / Long=32bit / LongLong=64bit。import ctypes
from ctypes import wintypes
PstGetCertificateChain = ctypes.windll.certpoleng.PstGetCertificateChain
PstGetCertificateChain.restype = ctypes.c_int
PstGetCertificateChain.argtypes = [
ctypes.c_void_p, # pCert : CERT_CONTEXT*
ctypes.c_void_p, # pTrustedIssuers : SecPkgContext_IssuerListInfoEx*
ctypes.c_void_p, # ppCertChainContext : CERT_CHAIN_CONTEXT** out
]require 'fiddle'
require 'fiddle/import'
lib = Fiddle.dlopen('certpoleng.dll')
PstGetCertificateChain = Fiddle::Function.new(
lib['PstGetCertificateChain'],
[
Fiddle::TYPE_VOIDP, # pCert : CERT_CONTEXT*
Fiddle::TYPE_VOIDP, # pTrustedIssuers : SecPkgContext_IssuerListInfoEx*
Fiddle::TYPE_VOIDP, # ppCertChainContext : CERT_CHAIN_CONTEXT** out
],
Fiddle::TYPE_INT)#[link(name = "certpoleng")]
extern "system" {
fn PstGetCertificateChain(
pCert: *const CERT_CONTEXT, // CERT_CONTEXT*
pTrustedIssuers: *mut SecPkgContext_IssuerListInfoEx, // SecPkgContext_IssuerListInfoEx*
ppCertChainContext: *mut *mut CERT_CHAIN_CONTEXT // CERT_CHAIN_CONTEXT** out
) -> i32;
}
// crates: windows-sys provides ready-made bindings for this API.$sig = @"
[DllImport("certpoleng.dll")]
public static extern int PstGetCertificateChain(IntPtr pCert, IntPtr pTrustedIssuers, IntPtr ppCertChainContext);
"@
$api = Add-Type -MemberDefinition $sig -Name 'certpoleng_PstGetCertificateChain' -Namespace Win32 -PassThru
# $api::PstGetCertificateChain(pCert, pTrustedIssuers, ppCertChainContext)#uselib "certpoleng.dll"
#func global PstGetCertificateChain "PstGetCertificateChain" sptr, sptr, sptr
; PstGetCertificateChain varptr(pCert), varptr(pTrustedIssuers), varptr(ppCertChainContext) ; 戻り値は stat
; pCert : CERT_CONTEXT* -> "sptr"
; pTrustedIssuers : SecPkgContext_IssuerListInfoEx* -> "sptr"
; ppCertChainContext : CERT_CHAIN_CONTEXT** out -> "sptr"
; ※HSP3.7は #func のため戻り値はシステム変数 stat に格納されます。出力引数:
#uselib "certpoleng.dll" #cfunc global PstGetCertificateChain "PstGetCertificateChain" var, var, var ; res = PstGetCertificateChain(pCert, pTrustedIssuers, ppCertChainContext) ; pCert : CERT_CONTEXT* -> "var" ; pTrustedIssuers : SecPkgContext_IssuerListInfoEx* -> "var" ; ppCertChainContext : CERT_CHAIN_CONTEXT** out -> "var" ; ※出力/バッファ引数は var 方式(変数を直接渡す)。varptr 方式にも切替可。#uselib "certpoleng.dll" #cfunc global PstGetCertificateChain "PstGetCertificateChain" sptr, sptr, sptr ; res = PstGetCertificateChain(varptr(pCert), varptr(pTrustedIssuers), varptr(ppCertChainContext)) ; pCert : CERT_CONTEXT* -> "sptr" ; pTrustedIssuers : SecPkgContext_IssuerListInfoEx* -> "sptr" ; ppCertChainContext : CERT_CHAIN_CONTEXT** out -> "sptr" ; ※出力/バッファ引数はポインタ方式(token=sptr / 呼び出しは varptr(変数))。
出力引数:
; NTSTATUS PstGetCertificateChain(CERT_CONTEXT* pCert, SecPkgContext_IssuerListInfoEx* pTrustedIssuers, CERT_CHAIN_CONTEXT** ppCertChainContext) #uselib "certpoleng.dll" #cfunc global PstGetCertificateChain "PstGetCertificateChain" var, var, var ; res = PstGetCertificateChain(pCert, pTrustedIssuers, ppCertChainContext) ; pCert : CERT_CONTEXT* -> "var" ; pTrustedIssuers : SecPkgContext_IssuerListInfoEx* -> "var" ; ppCertChainContext : CERT_CHAIN_CONTEXT** out -> "var" ; ※出力/バッファ引数は var 方式(変数を直接渡す)。varptr 方式にも切替可。; NTSTATUS PstGetCertificateChain(CERT_CONTEXT* pCert, SecPkgContext_IssuerListInfoEx* pTrustedIssuers, CERT_CHAIN_CONTEXT** ppCertChainContext) #uselib "certpoleng.dll" #cfunc global PstGetCertificateChain "PstGetCertificateChain" intptr, intptr, intptr ; res = PstGetCertificateChain(varptr(pCert), varptr(pTrustedIssuers), varptr(ppCertChainContext)) ; pCert : CERT_CONTEXT* -> "intptr" ; pTrustedIssuers : SecPkgContext_IssuerListInfoEx* -> "intptr" ; ppCertChainContext : CERT_CHAIN_CONTEXT** out -> "intptr" ; ※出力/バッファ引数はポインタ方式(token=intptr / 呼び出しは varptr(変数))。
import (
"golang.org/x/sys/windows"
"unsafe"
)
var (
certpoleng = windows.NewLazySystemDLL("certpoleng.dll")
procPstGetCertificateChain = certpoleng.NewProc("PstGetCertificateChain")
)
// pCert (CERT_CONTEXT*), pTrustedIssuers (SecPkgContext_IssuerListInfoEx*), ppCertChainContext (CERT_CHAIN_CONTEXT** out)
r1, _, err := procPstGetCertificateChain.Call(
uintptr(pCert),
uintptr(pTrustedIssuers),
uintptr(ppCertChainContext),
)
_ = err // syscall.Errno (valid when the call sets last-error)
_ = r1 // NTSTATUSfunction PstGetCertificateChain(
pCert: Pointer; // CERT_CONTEXT*
pTrustedIssuers: Pointer; // SecPkgContext_IssuerListInfoEx*
ppCertChainContext: Pointer // CERT_CHAIN_CONTEXT** out
): Integer; stdcall;
external 'certpoleng.dll' name 'PstGetCertificateChain';result := DllCall("certpoleng\PstGetCertificateChain"
, "Ptr", pCert ; CERT_CONTEXT*
, "Ptr", pTrustedIssuers ; SecPkgContext_IssuerListInfoEx*
, "Ptr", ppCertChainContext ; CERT_CHAIN_CONTEXT** out
, "Int") ; return: NTSTATUS●PstGetCertificateChain(pCert, pTrustedIssuers, ppCertChainContext) = DLL("certpoleng.dll", "int PstGetCertificateChain(void*, void*, void*)")
# 呼び出し: PstGetCertificateChain(pCert, pTrustedIssuers, ppCertChainContext)
# pCert : CERT_CONTEXT* -> "void*"
# pTrustedIssuers : SecPkgContext_IssuerListInfoEx* -> "void*"
# ppCertChainContext : CERT_CHAIN_CONTEXT** out -> "void*"
# なでしこ1は32bit・ANSI(Shift_JIS)。文字列=char*(ANSI)、ポインタ/ハンドル=void*(4byte)。