Java Card Technology for Smart Cards: Architecture and Programmer's Guide (Paperback)
暫譯: 智慧卡的 Java Card 技術:架構與程式設計師指南 (平裝本)

Zhiqun Chen

  • 出版商: Addison Wesley
  • 出版日期: 2000-06-06
  • 售價: $1,880
  • 貴賓價: 9.5$1,786
  • 語言: 英文
  • 頁數: 392
  • 裝訂: Paperback
  • ISBN: 0201703297
  • ISBN-13: 9780201703290
  • 相關分類: Java 程式語言
  • 已絕版

買這商品的人也買了...

相關主題

商品描述


Description

The first complete guide to Java Smart Cards and the new Java Card APIs!

  • Build flexible, dynamic, platform-independent smart card applications -- from start to finish.
  • Authoritative: By a member of the Java Card API team and leading financial Smart card application developer.
  • Includes detailed code examples and comprehensive API reference.
Smart cards are taking off: more than 3 billion will be in use by the end of the Year 2000. Smart card technologies and skills are in enormous demand -- especially, familiarity with Sun's Java Card API. This specification brings Java technology to smart cards, enabling card issuers to build breakthrough platform-independent solutions, run multiple applications on the same card, and respond to changing customer needs by installing applications even after a card has been issued. This book is the first complete programmer's guide and reference to the new Java Card 2.1 API. Through extensive code examples, it shows readers exactly how smart cards work -- and how to fully leverage the Java Card APIs in smart card development. Expert smart card developer and Java Card API team member Zhiqun Chen covers the entire Java Card language subset and all key programming concepts. Next, she presents a complete, integrated tutorial walking step-by-step through the creation of Java Card applets. The book also contains a thorough API reference. For all Java developers, smart card application developers, developers working with credit-card related applications, and builders of e-commerce and enterprise applications.

Zhiqun Chen was a member of the engineering team that designed and implemented the JavaCard APIs, and is currently implementing Sun's JavaCard Virtual Machine reference implementation. One of the leading developers of financial JavaCard applets, she has experience in developing Visa Open Platform card applications and MasterCard Mondex terminal and server applications for the Java Electronic Commerce Framework.

Back to Top


Appropriate Courses

Java--Intermediate Programming.

Back to Top


Table Of Contents

Foreword.
Preface.

I. INTRODUCTION.

1. From the Beginning.
Smart Cards.
Brief History.
Benefits.
Applications.

Challenges in the Development of Smart Card Applications.
Applying Java to Smart Cards.
Benefits of Java Card Technology.
Brief History of Java Card Technology.


2. Smart Card Basics.
Overview of Smart Cards.
Basic Card Types.
Memory Cards versus Microprocessor Cards.
Contact Cards versus Contactless Cards.

Smart Card Hardware.
Smart Card Contact Points.
Smart Card Central Processing Unit.
Smart Card Coprocessors.
Smart Card Memory System.

Smart Card Communication.
Card Acceptance Device and Host Applications.
Smart Card Communication Model.
APDU Protocol.
TPDU Protocol.
ATR.

Smart Card Operating Systems.
Smart Card File Systems.
Master File.
Dedicated File.
Elementary File.

Smart Card Systems.
Smart Card Standards and Specifications.
ISO 7816 Standards.
GSM.
EMV.
Open Platform.
OpenCard Framework.
PC/SC.

II. JAVA CARD TECHNOLOGY.



3. Java Card Technology Overview.
Architecture Overview.
Java Card Language Subset.
Java Card Virtual Machine.
CAP File and Export File.
Java Card Converter.
Java Card Interpreter.

Java Card Installer and Off-Card Installation Program.
Java Card Runtime Environment.
JCRE Lifetime.
How Does the JCRE Operate during a CAD Session?
Java Card Runtime Features.

Java Card APIs.
java.lang Package.
javacard.framework Package.
javacard.security Package.
javacardx.crypto Package.

Java Card Applets.
Package and Applet Naming Convention.
Applet Development Process.
Applet Installation.
ROM Applets.
Preissuance or Postissuance Applets.
Postissuance Applet Installation.
Error Recovery during Applet Installation.
Installation Constraints.

4. Java Card Objects.
Java Card Memory Model.
Persistent Objects.
Transient Objects.
Properties of Transient Objects.
Transient Object Types.
Creating Transient Objects.
Querying Transient Objects.

A Few Words about Object Creation and Deletion.

5. Atomicity and Transactions.
Atomicity.
Block Data Updates in an Array.
Transactions.
Commit Transaction.
Abort Transaction.
Nested Transaction.
Commit Capacity.
TransactionException.
Local Variables and Transient Objects during a Transaction.


6. Java Card Exceptions and Exception Handling.
Exceptions in the java.lang Package.
Java Card Exceptions.
Java Card Exception Reason Code.
Throwing an Exception in the Java Card Platform.
ISOException.
UserException.


7. Java Card Applets.
Applet Overview.
Applet Installation and Execution.
Applet Communication.

Class javacard.framework.Applet.
install Method.
Creating Objects in the Applet's Constructor.
Registering the Applet Instance with the JCRE.
Processing the Installation Parameters.
Further Applet Initialization.

select Method.
SELECT APDU Format and Processing.
Default Applet.

deselect Method.
process Method.
Other Methods in the Class javacard.framework.Applet.

8. Working with APDUs.
APDU Class.
APDU Object.
APDU Buffer Size.

Interface ISO7816.
Working with APDUs in Applets.
Retrieve the APDU Buffer.
Examine the Command APDU Header.
Receive APDU Command Data.
Process the APDU Command and Generate the Response Data.
Return APDU Response Data.
Return the Status Word.

Protocol-Specific APDU Processing.
Method getProtocol.
Method getInBlockSize.
Method getOutBlockSize.
Method setOutgoingNoChaining.
Method getNAD.
Method waitExtension.

Summary.

9. Applet Firewall and Object Sharing.
Applet Firewall.
Contexts.
Object Ownership.
Object Access.
Transient Array and Context.
Static Fields and Methods.

Object Sharing across Contexts.
Context Switch.
JCRE Privileges.
JCRE Entry Point Objects.
Global Arrays.
Object Shareable Interface Mechanism.


10. Programming Cryptography.
Quick Tour of Cryptography.
Encryption and Decryption.
Message Digest.
Digital Signature.
Random Data.

Cryptographic Practice in Smart Card Applications.
Ensuring Application Security.
Functioning as a Secure Token.
Summary.

Java Card Cryptography APIs.
Design Principles.
Architecture.
Package Structure.

Code Examples.
Compute a Message Digest.
Build a Cryptographic Key.
Sign and Verify a Signature.
Encrypt and Decrypt Data.
Generate Random Data.


11. Java Card Platform Security.
Java Card Platform Security Features.
Java Language Security.
Additional Security Features of the Java Card Platform.

Java Card Platform Security Mechanisms.
Compile-Time Checking.
Class File Verification and Subset Checking.
CAP File and Export File Verification.
Installation Checking.
Cryptographically Enforced Chain Trust.
Runtime Security Enforcement.
Java Card Cryptographic Support.

Applet Security.

III. PROGRAMMING GUIDE AND TIPS.


12. Step-by-Step Applet Development Guide.
Design the Applet.
Specify the Functions of the Applet.
Specify AIDs for the Applet.
Define the Class Structure and Method Functions of the Applet.
Define the Interface between the Applet and Its Host Application.

Construct the Applet Code.
Wallet Applet Code.
Implement Error Checking.

What's the Next Step?

13. Applet Optimization.
Optimizing an Applet's Overall Design.
On-Card Execution Time.
Method Invocations.
Creating Objects in Applets.
Reusing Objects.
Eliminating Redundant Code.
Accessing Arrays.
The switch Statement versus the if-else Statement.
Arithmetic Statements.
Optimizing Variables in Applets.

14. Working with int Data Type.
32-Bit Arithmetic Operations.
Array Size and Array Index.
Storing and Computing int Values.
Summary.

4 Appendices.


A. Java Card Language Subset.
B. Java Card Application Programming Interface.
Glossary.
Bibliography. 0201703297T04062001


Back to Top

商品描述(中文翻譯)

描述

第一本完整的 Java 智能卡和新的 Java Card API 指南!

- 從頭到尾構建靈活、動態、平台獨立的智能卡應用程序。
- 權威性:由 Java Card API 團隊成員及領先的金融智能卡應用開發者撰寫。
- 包含詳細的代碼示例和全面的 API 參考。

智能卡正在迅速普及:到 2000 年底將有超過 30 億張在使用。智能卡技術和技能的需求巨大,尤其是對 Sun 的 Java Card API 的熟悉程度。本規範將 Java 技術引入智能卡,使卡片發行者能夠構建突破性的平臺獨立解決方案,在同一張卡上運行多個應用程序,並通過在卡片發行後安裝應用程序來響應不斷變化的客戶需求。本書是第一本完整的程序員指南和新 Java Card 2.1 API 的參考。通過大量的代碼示例,它向讀者展示智能卡的工作原理,以及如何在智能卡開發中充分利用 Java Card API。專家智能卡開發者及 Java Card API 團隊成員陳志群涵蓋了整個 Java Card 語言子集和所有關鍵編程概念。接下來,她提供了一個完整的綜合教程,逐步講解 Java Card 應用程序的創建。本書還包含詳細的 API 參考。適合所有 Java 開發者、智能卡應用開發者、從事信用卡相關應用的開發者,以及電子商務和企業應用的建設者。

陳志群曾是設計和實現 Java Card API 的工程團隊成員,目前正在實施 Sun 的 Java Card 虛擬機參考實現。作為金融 Java Card 應用的主要開發者之一,她在開發 Visa 開放平台卡應用和 MasterCard Mondex 終端及伺服器應用方面擁有豐富經驗。

適合的課程

Java--中級編程。

目錄

- 前言。
- 序言。

I. 介紹。
1. 從開始開始。
- 智能卡。
- 簡要歷史。
- 優勢。
- 應用。
- 智能卡應用開發中的挑戰。
- 將 Java 應用於智能卡。
- Java Card 技術的優勢。
- Java Card 技術的簡要歷史。

2. 智能卡基礎。
- 智能卡概述。
- 基本卡類型。
- 記憶卡與微處理器卡。
- 接觸卡與非接觸卡。
- 智能卡硬體。
- 智能卡接觸點。
- 智能卡中央處理單元。
- 智能卡協處理器。
- 智能卡記憶系統。
- 智能卡通信。
- 卡片接受設備和主機應用。
- 智能卡通信模型。
- APDU 協議。
- TPDU 協議。
- ATR。
- 智能卡作業系統。
- 智能卡檔案系統。
- 主檔案。
- 專用檔案。
- 基本檔案。
- 智能卡系統。
- 智能卡標準和規範。
- ISO 7816 標準。
- GSM。
- EMV。
- 開放平台。
- OpenCard 框架。
- PC/SC。

II. JAVA CARD 技術。
3. Java Card 技術概述。
- 架構概述。
- Java Card 語言子集。
- Java Card 虛擬機。
- CAP 檔案和匯出檔案。
- Java Card 轉換器。
- Java Card 解釋器。
- Java Card 安裝程序和非卡安裝程序。
- Java Card 執行環境。
- JCRE 生命週期。
- JCRE 在 CAD 會話期間如何運作?
- Java Card 執行環境特性。
- Java Card API。
- java.lang 套件。
- javacard.framework 套件。
- javacard.security 套件。
- javacardx.crypto 套件。
- Java Card 應用程序。
- 套件和應用程序命名約定。
- 應用程序開發過程。
- 應用程序安裝。
- ROM 應用程序。
- 發行前或發行後的應用程序。
- 發行後應用程序安裝。
- 應用程序安裝過程中的錯誤恢復。
- 安裝限制。

4. Java Card 物件。
- Java Card 記憶模型。
- 持久物件。
- 瞬態物件。
- 瞬態物件的特性。
- 瞬態物件類型。
- 創建瞬態物件。
- 查詢瞬態物件。
- 關於物件創建和刪除的幾句話。

5. 原子性和交易。
- 原子性。
- 陣列中的區塊數據更新。
- 交易。
- 提交交易。
- 中止交易。
- 嵌套交易。
- 提交容量。
- TransactionException。
- 交易期間的局部變數和瞬態物件。

6. Java Card 異常和異常處理。
- java.lang 套件中的異常。
- Java Card 異常。
- Java Card 異常原因碼。
- 在 Java Card 平台中拋出異常。
- ISOException。
- UserException。

7. Java Card 應用程序。
- 應用程序概述。
- 應用程序的安裝和執行。
- 應用程序通信。
- javacard.framework.Applet 類。
- install 方法。
- 在應用程序的構造函數中創建物件。
- 將應用程序實例註冊到 JCRE。
- 處理安裝參數。
- 進一步的應用程序初始化。
- select 方法。
- SELECT APDU 格式和處理。
- 預設應用程序。
- deselect 方法。
- process 方法。
- javacard.framework.Applet 類中的其他方法。

8. 使用 APDU。
- APDU 類。
- APDU 物件。
- APDU 緩衝區大小。
- ISO7816 介面。
- 在應用程序中使用 APDU。
- 檢索 APDU 緩衝區。
- 檢查命令 APDU 標頭。
- 接收 APDU 命令數據。
- 處理 APDU 命令並生成響應數據。
- 返回 APDU 響應數據。
- 返回狀態字。
- 協議特定的 APDU 處理。
- getProtocol 方法。
- getInBlockSize 方法。
- getOutBlockSize 方法。
- setOutgoingNoChaining 方法。
- getNAD 方法。
- waitExtension 方法。
- 總結。

9. 應用程序防火牆和物件共享。
- 應用程序防火牆。
- 上下文。
- 物件擁有權。
- 物件訪問。
- 瞬態陣列和上下文。
- 靜態欄位和方法。
- 跨上下文的物件共享。
- 上下文切換。
- JCRE 權限。
- JCRE 入口點物件。
- 全域陣列。
- 物件可共享介面機制。

10. 編程密碼學。
- 密碼學快速導覽。
- 加密和解密。
- 訊息摘要。
- 數位簽名。
- 隨機數據。
- 智能卡應用中的密碼學實踐。
- 確保應用安全。
- 作為安全令牌的功能。
- 總結。
- Java Card 密碼學 API。
- 設計原則。
- 架構。
- 套件結構。
- 代碼示例。
- 計算訊息摘要。
- 建立密碼學金鑰。
- 簽署和驗證簽名。
- 加密和解密數據。
- 生成隨機數據。

11. Java Card 平台安全性。
- Java Card 平台安全特性。
- Java 語言安全性。
- Java Card 平台的其他安全特性。
- Java Card 平台安全機制。
- 編譯時檢查。
- 類檔案驗證和子集檢查。
- CAP 檔案和匯出檔案驗證。
- 安裝檢查。
- 密碼學強制的鏈信任。
- 執行時安全強制。
- Java Card 密碼學支持。
- 應用程序安全。

III. 編程指南和技巧。
12. 步驟式應用程序開發指南。
- 設計應用程序。
- 指定應用程序的功能。
- 為應用程序指定 AID。
- 定義應用程序的類結構和方法功能。
- 定義應用程序與其主機應用之間的介面。
- 構建應用程序代碼。
- 錢包應用程序代碼。
- 實施錯誤檢查。
- 下一步是什麼?

13. 應用程序優化。
- 優化應用程序的整體設計。
- 卡片執行時間。
- 方法調用。
- 在應用程序中創建物件。
- 重用物件。
- 消除冗餘代碼。
- 訪問陣列。
- switch 語句與 if-else 語句。
- 算術語句。
- 優化應用程序中的變數。

14. 使用 int 數據類型。
- 32 位算術運算。
- 陣列大小和陣列索引。
- 儲存和計算 int 值。
- 總結。

附錄。
A. Java Card 語言子集。
B. Java Card 應用程式介面。
詞彙表。
參考書目。