차이

문서의 선택한 두 판 사이의 차이를 보여줍니다.

차이 보기로 링크

양쪽 이전 판 이전 판
다음 판
이전 판
ko:smartcard_api [2018/02/21 09:23]
yjjung [BS2CSNCard]
ko:smartcard_api [2021/09/14 14:37] (현재)
mark
줄 7: 줄 7:
   * [[BS2_WriteCard]]:​ SmartCard에 데이터를 저장합니다.   * [[BS2_WriteCard]]:​ SmartCard에 데이터를 저장합니다.
   * [[BS2_EraseCard]]:​ SmartCard를 포맷합니다.   * [[BS2_EraseCard]]:​ SmartCard를 포맷합니다.
 +
 ===== 구조체 ====== ===== 구조체 ======
 ==== BS2CSNCard ==== ==== BS2CSNCard ====
줄 21: 줄 22:
 <WRAP group 100%> <WRAP group 100%>
 ^값      ^설명 ​    ​^사용된 형식 ​  ^ ^값      ^설명 ​    ​^사용된 형식 ​  ^
-|0x00 |알려지지 않은 카드 ​ | +|0x00 |알려지지 않은 카드 ​ ​| ​ | 
-|0x01 |CSN 카드 ​   | +|0x01 |CSN 카드 ​   ​|  ​
-|0x02 |Secure 카드 ​   | +|0x02 |Secure 카드 ​   ​|  ​
-|0x03 |Access 카드 ​ |+|0x03 |Access 카드 ​ ​| ​ | 
 +|0x06 |QR 코드 ​ |  |
 |0x0A |Wiegand 카드 ​ | BS2WiegandConfig.format (이 형식은 ​ BS2WiegandConfig.CSNIndex 혹은 BS2WiegandConfig.CardMask가 0으로 설정될 때 사용됩니다. | |0x0A |Wiegand 카드 ​ | BS2WiegandConfig.format (이 형식은 ​ BS2WiegandConfig.CSNIndex 혹은 BS2WiegandConfig.CardMask가 0으로 설정될 때 사용됩니다. |
 +|0x0B |Config 카드 ​ |
 |0x1A |Wiegand 카드 ​ | BS2WiegandMultiConfig.formats[0] | |0x1A |Wiegand 카드 ​ | BS2WiegandMultiConfig.formats[0] |
 |0x2A |Wiegand 카드 ​ | BS2WiegandMultiConfig.formats[1] | |0x2A |Wiegand 카드 ​ | BS2WiegandMultiConfig.formats[1] |
줄 44: 줄 47:
  
 **2. //size//** \\  **2. //size//** \\ 
-카드 템플릿의 ​크기입니다. \\ \\ +데이터 버퍼 사이즈 ​크기입니다. \\ \\ 
 **3. //data//** \\  **3. //data//** \\ 
 카드 템플릿 데이터입니다. \\  카드 템플릿 데이터입니다. \\ 
줄 58: 줄 61:
     uint16_t issueCount;     uint16_t issueCount;
     uint8_t duressMask;     uint8_t duressMask;
-    uint8_t reserved[5]; +    ​uint8_t cardAuthMode;​ 
-} BS2SmartCardHeader; ​ +    uint8_t useAlphanumericID;​ 
 +    uint8_t cardAuthModeEx;​ 
 +    uint8_t numOfFaceTemplate;​ 
 +    ​uint8_t reserved[1]; 
 +} BS2SmartCardHeader;​
 </​code>​ </​code>​
 **1. //​hdrCRC//​** \\  **1. //​hdrCRC//​** \\ 
-card header 체크섬 값입니다. \\ \\ +card header 체크섬 값입니다. ​(cardCRC - reserved)  ​\\ \\ 
 **2. //​cardCRC//​** \\  **2. //​cardCRC//​** \\ 
-card data 체크섬 값입니다. \\ \\ +card data 체크섬 값입니다. ​(BS2SmartCardHeader.cardType - BS2SmartCardData.accessOnData) ​\\ \\ 
 **3. //​cardType//​** \\  **3. //​cardType//​** \\ 
 카드 유형의 코드 값입니다. \\  카드 유형의 코드 값입니다. \\ 
 <WRAP group 50%> <WRAP group 50%>
 ^값  ^설명 ​ ^ ^값  ^설명 ​ ^
-|0 |알려지지 않은 카드 ​ | +|0x00 |알려지지 않은 카드 ​ | 
-|1 |CSN 카드 ​ | +|0x01 |CSN 카드 ​ | 
-|2 |Secure 카드 ​ | +|0x02 |Secure 카드 ​ | 
-|3 |Access 카드 ​ | +|0x03 |Access 카드 ​ | 
-||Wiegand 카드 ​ |+|0x0A |Wiegand ​카드 ​ | 
 +|0x0B |Config ​카드 ​ |
 </​WRAP>​ </​WRAP>​
  
 **4. //​numOfTemplate//​** \\  **4. //​numOfTemplate//​** \\ 
-지문 템플릿의 개수입니다. \\ \\ +지문 템플릿의 개수입니다. \\  
 +<WRAP important>​AOC 카드 구조상 template은 [[smartcard_api#​BS2SmartCardCredentials]]에 저장됩니다. ​\\ 
 +그리고 이곳에는 지문 또는 얼굴이 선택적으로 저장되어집니다. 지문과 얼굴이 함께 저장되어지지 않습니다. \\ 
 +따라서 AOC 카드에 지문 template을 담고자 한다면, numOfFacetemplate은 반드시 0으로 설정 되어야 합니다. 
 +</​WRAP>​ 
 **5. //​templateSize//​** \\  **5. //​templateSize//​** \\ 
 지문 템플릿의 크기입니다. 일반적인 지문 템플릿의 크기는 384 바이트로 고정되어 있습니다. \\ 지문 템플릿의 크기입니다. 일반적인 지문 템플릿의 크기는 384 바이트로 고정되어 있습니다. \\
줄 86: 줄 99:
 **7. //​duressMask//​** \\  **7. //​duressMask//​** \\ 
 협박 지문 유무 마스크 값입니다. \\  협박 지문 유무 마스크 값입니다. \\ 
 +**8. //​cardAuthMode//​** \\ 
 +''​FaceStation F2 이외''​ 카드 인증 모드 설정값입니다. \\ 
 +''​FaceStation F2''​ **cardAuthModeEx**를 사용합니다. \\ 
 +<WRAP group 50%>
 +^값  ^설명 ​ ^
 +|2 |카드 인증만 사용 ​  |
 +|3 |카드와 지문 인증 사용 ​  |
 +|4 |카드와 PIN 인증 사용 ​ |
 +|5 |카드 인증 후 지문이나 PIN 인증 사용 ​  |
 +|6 |카드, 지문, PIN 인증 사용 ​  |
 +|254 |사용할 수 없음 ​ |
 +|255 |정의되지 않음(시스템에 정의된 모드로 동작) ​ |
 +</​WRAP>​
 +**9. //​useAlphanumericID//​** \\ 
 +Alphanumeric ID를 사용할지 결정하는 flag입니다. \\ 
 +**10. //​cardAuthModeEx//​** \\ 
 +''​FaceStation F2 이외''​ **cardAuthMode**를 사용합니다. \\ 
 +[+ V2.7.1] ''​FaceStation F2''​ 카드 인증 모드 설정값입니다. \\ 
 +<WRAP group 60%>
 +^값  ^1단계 인증 ​ ^2단계 인증 ​ ^3단계 인증 ​ ^
 +|21  |카드 ​ |      |   |
 +|22  |카드 ​ |얼굴 ​ |   |
 +|23  |카드 ​ |지문 ​ |   |
 +|24  |카드 ​ |PIN  |   |
 +|25  |카드 ​ |얼굴 또는 지문 ​ |   |
 +|26  |카드 ​ |얼굴 또는 PIN  |   |
 +|27  |카드 ​ |지문 또는 PIN  |   |
 +|28  |카드 ​ |얼굴 또는 지문 또는 PIN  |   |
 +|29  |카드 ​ |얼굴 ​ |지문 ​ |
 +|30  |카드 ​ |얼굴 ​ |PIN  |
 +|31  |카드 ​ |지문 ​ |얼굴 ​ |
 +|32  |카드 ​ |지문 ​ |PIN  |
 +|33  |카드 ​ |얼굴 또는 지문 ​ |PIN  |
 +|34  |카드 ​ |얼굴 ​ |지문 또는 PIN  |
 +|35  |카드 ​ |지문 ​ |얼굴 또는 PIN  |
 +|254 |사용할 수 없음 ​ |  |  |
 +|255 |정의되지 않음(시스템 정의 모드) ​ |  |  |
 +</​WRAP>​
 +**11. //​numOfFaceTemplate//​** \\ 
 +얼굴 템플릿 수를 나타냅니다. \\
 +지문과 얼굴이 갖는 기본적인 template의 크기가 다르지만 (지문:​384,​ 얼굴:552) \\
 +이경우에도 변함없이 [[smartcard_api#​BS2SmartCardCredentials]]의 templateData의 전체크기를 고려하여 저장하시면 됩니다. \\
 +<WRAP important>​AOC 카드 구조상 template은 [[smartcard_api#​BS2SmartCardCredentials]]에 저장됩니다. \\
 +그리고 이곳에는 지문 또는 얼굴이 선택적으로 저장되어집니다. 지문과 얼굴이 함께 저장되어지지 않습니다. \\
 +따라서 AOC 카드에 얼굴 template을 담고자 한다면, numOfTemplate은 반드시 0으로 설정 되어야 합니다.
 +</​WRAP>​
 +
 +**12. //​reserved//​** \\ 
 +예약된 공간입니다. \\ 
  
 ==== BS2SmartCardCredentials ==== ==== BS2SmartCardCredentials ====
줄 126: 줄 188:
 SmartCard 헤더입니다. \\ \\  SmartCard 헤더입니다. \\ \\ 
 **2. //​cardID//​** \\  **2. //​cardID//​** \\ 
-단말기에서 사용할 카드 식별자입니다. Access on Card의 경우 배열의 32 byte를 Card ID로 +단말기에서 사용할 카드 식별자입니다. ​\\ 
- 사용하고,​ Secure Credential card는 배열의 24 byte를 Card ID로 사용하게 됩니다. \\ \\ +Access on Card의 경우 배열의 32 byte를 Card ID로 사용하고, ​\\ 
 +Secure Credential card는 배열의 24 byte를 Card ID로 사용하게 됩니다. \\ 
 +Secure Credential Card(SCC)의 경우, 32 byte는 Card ID(24 bytes), issueCount(4 byte) 그리고 Time Stamp(4 byte)로 채워져야 합니다. \\ 
 +또한, BS2UserBlob 구조체의 cardObjs array가 SC Card로 채워야 하며, SC Card 발급시마다 cardObjs 업데이트 되어야 합니다. \\ \\
 **3. //​credentials//​** \\  **3. //​credentials//​** \\ 
 pin code나 지문 템플릿이 저장되어 있는 인증 데이터 영역입니다. \\ \\  pin code나 지문 템플릿이 저장되어 있는 인증 데이터 영역입니다. \\ \\