Win32 API 日本語リファレンス
ホームSecurity.Credentials › SCardConnectA

SCardConnectA

関数
指定リーダーのスマートカードへ接続する。
DLLWinSCard.dll文字セットANSI (-A)呼出規約winapi対応OSWindows XP 以降

シグネチャ

// WinSCard.dll  (ANSI / -A)
#include <windows.h>

INT SCardConnectA(
    UINT_PTR hContext,
    LPCSTR szReader,
    DWORD dwShareMode,
    DWORD dwPreferredProtocols,
    UINT_PTR* phCard,
    DWORD* pdwActiveProtocol
);

パラメーター

名前方向
hContextUINT_PTRin
szReaderLPCSTRin
dwShareModeDWORDin
dwPreferredProtocolsDWORDin
phCardUINT_PTR*out
pdwActiveProtocolDWORD*out

戻り値の型: INT

各言語での呼び出し定義

// WinSCard.dll  (ANSI / -A)
#include <windows.h>

INT SCardConnectA(
    UINT_PTR hContext,
    LPCSTR szReader,
    DWORD dwShareMode,
    DWORD dwPreferredProtocols,
    UINT_PTR* phCard,
    DWORD* pdwActiveProtocol
);
[DllImport("WinSCard.dll", CharSet = CharSet.Ansi, ExactSpelling = true)]
static extern int SCardConnectA(
    UIntPtr hContext,   // UINT_PTR
    [MarshalAs(UnmanagedType.LPStr)] string szReader,   // LPCSTR
    uint dwShareMode,   // DWORD
    uint dwPreferredProtocols,   // DWORD
    out UIntPtr phCard,   // UINT_PTR* out
    out uint pdwActiveProtocol   // DWORD* out
);
<DllImport("WinSCard.dll", CharSet:=CharSet.Ansi, ExactSpelling:=True)>
Public Shared Function SCardConnectA(
    hContext As UIntPtr,   ' UINT_PTR
    <MarshalAs(UnmanagedType.LPStr)> szReader As String,   ' LPCSTR
    dwShareMode As UInteger,   ' DWORD
    dwPreferredProtocols As UInteger,   ' DWORD
    <Out> ByRef phCard As UIntPtr,   ' UINT_PTR* out
    <Out> ByRef pdwActiveProtocol As UInteger   ' DWORD* out
) As Integer
End Function
' hContext : UINT_PTR
' szReader : LPCSTR
' dwShareMode : DWORD
' dwPreferredProtocols : DWORD
' phCard : UINT_PTR* out
' pdwActiveProtocol : DWORD* out
Declare PtrSafe Function SCardConnectA Lib "winscard" ( _
    ByVal hContext As LongPtr, _
    ByVal szReader As String, _
    ByVal dwShareMode As Long, _
    ByVal dwPreferredProtocols As Long, _
    ByRef phCard As LongPtr, _
    ByRef pdwActiveProtocol As Long) As Long
' VBA7前提(PtrSafe)。32bit Office では LongPtr→Long。Integer=16bit / Long=32bit / LongLong=64bit。
import ctypes
from ctypes import wintypes

SCardConnectA = ctypes.windll.winscard.SCardConnectA
SCardConnectA.restype = ctypes.c_int
SCardConnectA.argtypes = [
    ctypes.c_size_t,  # hContext : UINT_PTR
    wintypes.LPCSTR,  # szReader : LPCSTR
    wintypes.DWORD,  # dwShareMode : DWORD
    wintypes.DWORD,  # dwPreferredProtocols : DWORD
    ctypes.POINTER(ctypes.c_size_t),  # phCard : UINT_PTR* out
    ctypes.POINTER(wintypes.DWORD),  # pdwActiveProtocol : DWORD* out
]
require 'fiddle'
require 'fiddle/import'

lib = Fiddle.dlopen('WinSCard.dll')
SCardConnectA = Fiddle::Function.new(
  lib['SCardConnectA'],
  [
    Fiddle::TYPE_UINTPTR_T,  # hContext : UINT_PTR
    Fiddle::TYPE_VOIDP,  # szReader : LPCSTR
    -Fiddle::TYPE_INT,  # dwShareMode : DWORD
    -Fiddle::TYPE_INT,  # dwPreferredProtocols : DWORD
    Fiddle::TYPE_VOIDP,  # phCard : UINT_PTR* out
    Fiddle::TYPE_VOIDP,  # pdwActiveProtocol : DWORD* out
  ],
  Fiddle::TYPE_INT)
#[link(name = "winscard")]
extern "system" {
    fn SCardConnectA(
        hContext: usize,  // UINT_PTR
        szReader: *const u8,  // LPCSTR
        dwShareMode: u32,  // DWORD
        dwPreferredProtocols: u32,  // DWORD
        phCard: *mut usize,  // UINT_PTR* out
        pdwActiveProtocol: *mut u32  // DWORD* out
    ) -> i32;
}
// crates: windows-sys provides ready-made bindings for this API.
$sig = @"
[DllImport("WinSCard.dll", CharSet = CharSet.Ansi)]
public static extern int SCardConnectA(UIntPtr hContext, [MarshalAs(UnmanagedType.LPStr)] string szReader, uint dwShareMode, uint dwPreferredProtocols, out UIntPtr phCard, out uint pdwActiveProtocol);
"@
$api = Add-Type -MemberDefinition $sig -Name 'WinSCard_SCardConnectA' -Namespace Win32 -PassThru
# $api::SCardConnectA(hContext, szReader, dwShareMode, dwPreferredProtocols, phCard, pdwActiveProtocol)
#uselib "WinSCard.dll"
#func global SCardConnectA "SCardConnectA" sptr, sptr, sptr, sptr, sptr, sptr
; SCardConnectA hContext, szReader, dwShareMode, dwPreferredProtocols, varptr(phCard), varptr(pdwActiveProtocol)   ; 戻り値は stat
; hContext : UINT_PTR -> "sptr"
; szReader : LPCSTR -> "sptr"
; dwShareMode : DWORD -> "sptr"
; dwPreferredProtocols : DWORD -> "sptr"
; phCard : UINT_PTR* out -> "sptr"
; pdwActiveProtocol : DWORD* out -> "sptr"
; ※HSP3.7は #func のため戻り値はシステム変数 stat に格納されます。
出力引数:
#uselib "WinSCard.dll"
#cfunc global SCardConnectA "SCardConnectA" sptr, str, int, int, var, var
; res = SCardConnectA(hContext, szReader, dwShareMode, dwPreferredProtocols, phCard, pdwActiveProtocol)
; hContext : UINT_PTR -> "sptr"
; szReader : LPCSTR -> "str"
; dwShareMode : DWORD -> "int"
; dwPreferredProtocols : DWORD -> "int"
; phCard : UINT_PTR* out -> "var"
; pdwActiveProtocol : DWORD* out -> "var"
; ※出力/バッファ引数は var 方式(変数を直接渡す)。varptr 方式にも切替可。
出力引数:
; INT SCardConnectA(UINT_PTR hContext, LPCSTR szReader, DWORD dwShareMode, DWORD dwPreferredProtocols, UINT_PTR* phCard, DWORD* pdwActiveProtocol)
#uselib "WinSCard.dll"
#cfunc global SCardConnectA "SCardConnectA" intptr, str, int, int, var, var
; res = SCardConnectA(hContext, szReader, dwShareMode, dwPreferredProtocols, phCard, pdwActiveProtocol)
; hContext : UINT_PTR -> "intptr"
; szReader : LPCSTR -> "str"
; dwShareMode : DWORD -> "int"
; dwPreferredProtocols : DWORD -> "int"
; phCard : UINT_PTR* out -> "var"
; pdwActiveProtocol : DWORD* out -> "var"
; ※出力/バッファ引数は var 方式(変数を直接渡す)。varptr 方式にも切替可。
import (
	"golang.org/x/sys/windows"
	"unsafe"
)

var (
	winscard = windows.NewLazySystemDLL("WinSCard.dll")
	procSCardConnectA = winscard.NewProc("SCardConnectA")
)

// hContext (UINT_PTR), szReader (LPCSTR), dwShareMode (DWORD), dwPreferredProtocols (DWORD), phCard (UINT_PTR* out), pdwActiveProtocol (DWORD* out)
r1, _, err := procSCardConnectA.Call(
	uintptr(hContext),
	uintptr(unsafe.Pointer(windows.BytePtrFromString(szReader))),
	uintptr(dwShareMode),
	uintptr(dwPreferredProtocols),
	uintptr(phCard),
	uintptr(pdwActiveProtocol),
)
_ = err  // syscall.Errno (valid when the call sets last-error)
_ = r1   // INT
function SCardConnectA(
  hContext: NativeUInt;   // UINT_PTR
  szReader: PAnsiChar;   // LPCSTR
  dwShareMode: DWORD;   // DWORD
  dwPreferredProtocols: DWORD;   // DWORD
  phCard: Pointer;   // UINT_PTR* out
  pdwActiveProtocol: Pointer   // DWORD* out
): Integer; stdcall;
  external 'WinSCard.dll' name 'SCardConnectA';
result := DllCall("WinSCard\SCardConnectA"
    , "UPtr", hContext   ; UINT_PTR
    , "AStr", szReader   ; LPCSTR
    , "UInt", dwShareMode   ; DWORD
    , "UInt", dwPreferredProtocols   ; DWORD
    , "Ptr", phCard   ; UINT_PTR* out
    , "Ptr", pdwActiveProtocol   ; DWORD* out
    , "Int")   ; return: INT
●SCardConnectA(hContext, szReader, dwShareMode, dwPreferredProtocols, phCard, pdwActiveProtocol) = DLL("WinSCard.dll", "int SCardConnectA(int, char*, dword, dword, void*, void*)")
# 呼び出し: SCardConnectA(hContext, szReader, dwShareMode, dwPreferredProtocols, phCard, pdwActiveProtocol)
# hContext : UINT_PTR -> "int"
# szReader : LPCSTR -> "char*"
# dwShareMode : DWORD -> "dword"
# dwPreferredProtocols : DWORD -> "dword"
# phCard : UINT_PTR* out -> "void*"
# pdwActiveProtocol : DWORD* out -> "void*"
# なでしこ1は32bit・ANSI(Shift_JIS)。文字列=char*(ANSI)、ポインタ/ハンドル=void*(4byte)。