Java Card CAP組件分析——Header Component

Header組件中包含了該CAP文件的基本信息,其中包括最重要的文件版本信息和包AID值。版本信息用以判斷JAVA卡是否支持對該文件的解析。AID是CAP文件的唯一識別,單張JAVA智能卡上不支持裝載相同AID的CAP文件。
  1. header_component {  
  2.     u1 tag  
  3.     u2 size  
  4.     u4 magic    // 必須爲0xDECAFFE  
  5.     u1 minor_version  
  6.     u1 major_version  
  7.     u1 flags    // ACC_INT - 0x01; ACC_EXPORT - 0x02; ACC_APPLET - 0x04  
  8.     package_info package  
  9.     package_name_info package_name  
  10. }  

其中CAP File Package Flags:

Flags Value

ACC_INT

0×01

ACC_EXPORT

0×02

ACC_APPLET

0×04

  1. package_info {  
  2.     u1 minor_version  
  3.     u1 major_version  
  4.     u1 AID_length  
  5.     u1 AID[AID_length]  
  6. }  
  7.  1  
  8. 2  
  9. 3  
  10. 4  
  11. package_name_info {  
  12.     u1 name_length  // 當包內沒有定義任何remote interfaces或者remote classes的時候值可以爲0  
  13.     u1 name[name_length]  
  14. }  

以 HelloWorld.cap 文件中的Header.cap中的信息爲例:

0×01 | 0×00 0×13 | 0xDE 0xCA 0xFF 0xED | 0×01 | 0×02 | 0×04 |0×00 0×01 | 0×09 | 0xA0 0×00 0×00 0×00 0×62 0×03 0×01 0x0C 0×01

  • tag: 0×01 COMPONENT_Header
  • size: 0×13 = 19 除去tag和size後的大小
  • magic: 0xDECAFFED 用以標識Java卡CAP文件格式,若一個文件不是以0xDECAFFED開頭則肯定不是JavaCard CAP文件,因爲它不符合規範
  • minor_version: 0×01 次版本號
  • major_version: 0×02 主版本號, 該CAP文件格式的版本號是02.01;如果CAP文件的版本號超出了Java虛擬機所能夠處理的有效範圍,Java虛擬機將不會處理該CAP文件
  • flag: 0×04 包中沒有用到int類型、CAP文件中沒有Export組件、CAP文件中有Applet組件。
  • package_info:
    • minor_version: 0×00
    • major_version: 0×01
    • AID_length: 0×09
    • AID: 0xA0 0×00 0×00 0×00 0×62 0×03 0×01 0x0C 0×01
對應卡內installer:
  1. CardApplet* newapplet=new CardApplet();  
  2. int iPos = 0;  
  3. u1 c1;  
  4.    
  5. c1=dataBuffer[iPos];  
  6.    
  7. // Read Header Component  
  8.    
  9. if(c1!=TAG_HEADER_COMP){  
  10.     std::cerr<<"Not an applet!"<<std::endl;  
  11. }  
  12. else  
  13. {  
  14.     iPos+=7;  
  15.    
  16.     u1 appletMinVer  = dataBuffer[iPos++];  
  17.     u1 appletMajVer  = dataBuffer[iPos++];  
  18.     u1 appletFlags   = dataBuffer[iPos++];  
  19.     u1 packageMinVer = dataBuffer[iPos++];  
  20.     u1 packageMajVer = dataBuffer[iPos++];  
  21.     u1 aidLength     = dataBuffer[iPos++];  
  22.     u1* aid          = new u1[(int)aidLength];  
  23.     for(int i=0;i<aidLength;i++)  
  24.     {  
  25.         aid[i]=dataBuffer[iPos++];  
  26.     }  
  27.    
  28.     PackageInfo* pi = new PackageInfo(aid,aidLength,packageMajVer,packageMinVer);  
  29.     newapplet->pHeader = new HeaderComponent(pi,appletMajVer,appletMinVer,appletFlags);  
  30.    
  31. }  
作者:fish
轉自:http://www.dreamingfish123.info/?p=684
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章