版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
1、單片機(jī)智能卡設(shè)計(jì)單片機(jī)智能卡設(shè)計(jì) 引言 -智能卡(SmartCard)又稱集成電路卡(Integrated Circuit Card,即IC卡),將微電子技術(shù)和單片機(jī)技術(shù)結(jié)合在一起,具有高的可靠性、安全性和靈活性,其廣泛地應(yīng)用于電信、金融、交通及公共事業(yè)等領(lǐng)域。智能卡接口控制器是連接智能卡和主控設(shè)備的橋梁,是智能卡處理設(shè)備中的最重要組成部分之一。面對(duì)龐大的市場需求,各大芯片廠商都推出了各自的智能卡接口控制器芯片,例如,Philips 的 8007、Linear的 LTC1755/6 等。本文也提出一種實(shí)用的智能卡接口控制器的設(shè)計(jì)方案。 單片機(jī)智能卡設(shè)計(jì)的硬件結(jié)構(gòu) 讀寫器的硬件組成如圖 1 所示
2、。包括電源、單片機(jī)系統(tǒng)、RS 232接口、IC卡讀寫接口、多路 時(shí)鐘系統(tǒng)和復(fù)位電路等幾個(gè)主要部分。 單片機(jī)系統(tǒng)由 89C52CPU、三態(tài)地址鎖存器和靜態(tài)存貯器組成。89C52的P0口與三態(tài)地址鎖存 器形成地址總線的低8位,即A0A7,以及數(shù)據(jù)總線D0D7;89C52的 P2.0P2.6 形成地址 總線的高8 位,即A8A12。靜態(tài)存貯器用于保存讀寫器運(yùn)行過程中預(yù)設(shè)的一系列軟件指令。串行接口用于實(shí)現(xiàn)讀寫器與用戶端設(shè)備,如 PC 機(jī)等之間的數(shù)據(jù)通信。在當(dāng)前系統(tǒng)中采用了一片 MAX232,其中的 RXD、TXD 做為數(shù)據(jù)的 I/O 通道接 CPU 串行口,完成讀寫器 CPU 與外部間的數(shù)據(jù)交換。同時(shí)
3、,外部用戶端還可通過串口的 RTS 信號(hào)對(duì) IC 卡讀寫器進(jìn)行軟件上的復(fù)位。 通用的智能卡多為異步型 CPU 卡,在其時(shí)鐘方面多需要不同的控制和發(fā)生體系。因此在讀寫 器中設(shè)置有專門的時(shí)鐘電路和時(shí)鐘控制電路,主要由 74LS253 雙四選一電路及 D 觸發(fā)器等組成 。晶振提供的脈沖經(jīng)分頻產(chǎn)生時(shí)鐘信號(hào)分別送到四選一電路輸入端。另外 2 個(gè)輸入端分別接地和 T0(89C52CPU 的 T0 引腳),T0 信號(hào)通過軟件編程分頻后向 IC 卡提供時(shí)鐘信號(hào),時(shí)鐘頻率、脈沖寬度可由具體編程決定。四選一電路的選擇控制端分別接P1.0和P1.1、P1.0和P1.1,分別對(duì)應(yīng)于不同的頻率關(guān)系。 在讀寫器的硬件構(gòu)成
4、上,還提供有上/下電控制電路。這部分電路用于控制對(duì)卡的上電和下 電操作,也就是提供對(duì)卡的電源開關(guān)控制。主要由 89C52 的 P1.7、R3,R4和三極管 Q2 等組成開關(guān)電路來控制對(duì)卡的上/下電。當(dāng)需要給 IC 卡加電時(shí),通過預(yù)先設(shè)定的程序使 P17 置“0”,使 Q2 導(dǎo)通,VCC 通過 Q2 將 CVCC 送至IC 卡;當(dāng) I C 卡下電時(shí),置 P1.7 為“1”使Q2 截止,從而禁止向 IC 卡供電。詳細(xì)電路如圖 2所示。 作為用戶與 IC 卡之間的交互平臺(tái),讀寫器需要分別建立與外部用戶和內(nèi)部 IC 卡之間
5、的數(shù)據(jù)通 信體系。讀寫器中的IC卡接口即提供讀寫器與IC卡間進(jìn)行數(shù)據(jù)交換的通道。根據(jù)目前通用的IC卡接口標(biāo)準(zhǔn),與IC卡的接口基本上由 8 個(gè)信號(hào)組成:CLK 時(shí)鐘、I/O 數(shù)據(jù)、RST 復(fù)位等,另外有 3 個(gè) NC 信號(hào)供用戶自己定義。將他們分別與讀寫器中CPU接口線相連,再由CPU通過預(yù)設(shè)的軟件指令控制和實(shí)現(xiàn)與 IC 卡間的數(shù)據(jù)交換,如圖 3 所示。 3 讀寫器的軟件體系 用戶以何種方式和過程使用讀寫器是讀寫器開發(fā)中的關(guān)鍵部分之一,其核心目標(biāo)是在設(shè)備硬件體系的基礎(chǔ)上,開發(fā)并提供一個(gè)使用戶能夠?qū)τ布M(jìn)行直接操作的軟件層,這個(gè)軟件層部分包括的主要是一系列的應(yīng)用協(xié)議和與其相配合的控制程序。在使用讀
6、寫器的過程中,PC 機(jī)或其他外部用戶系統(tǒng)必須遵循或借助于這些協(xié)議,才能夠與讀寫器內(nèi)部的控制程序正確互動(dòng)和協(xié)調(diào)一致,以實(shí)現(xiàn)對(duì)設(shè)備有效的使用。依據(jù)實(shí)際的應(yīng)用要求,該讀寫器的軟件體系主要包含以下幾個(gè)組成部分。 3.1 對(duì)讀寫器的啟動(dòng) 用戶在開始使用讀寫器,也就是要求與讀寫器進(jìn)行數(shù)據(jù)通信前,首先需對(duì)設(shè)備進(jìn)行復(fù)位,使其加電啟動(dòng)系統(tǒng)并進(jìn)入待機(jī)狀態(tài)。 具體實(shí)施過程為 PC 機(jī)端首先通過已選擇好的串口,根據(jù)標(biāo)準(zhǔn)串口通信協(xié)議發(fā)送一個(gè)正脈沖至 讀寫器端的RTS 引腳。同時(shí)在讀寫器中,為了使用戶(如 PC 機(jī))能夠驗(yàn)證設(shè)備的當(dāng)前復(fù)位狀態(tài),在讀寫器被正確復(fù)位后,其上的控制系統(tǒng)會(huì)發(fā)送一個(gè)第一響應(yīng)碼至用戶端,在用戶正確接
7、收到后,需返回一個(gè)第二響應(yīng)碼至讀寫器,使讀寫器端與用戶端能夠相互確認(rèn)并建立起正確有效的通信體系。否則在用戶端需要繼續(xù)等待,讀寫器在一定限時(shí)內(nèi)會(huì)重發(fā)第一響應(yīng)碼。但如果用戶端長時(shí)間未能收到正確數(shù)據(jù),此時(shí)重新進(jìn)行復(fù)位操作。 3.2 通信“握手” 為保證數(shù)據(jù)通信過程的正確有效,使讀寫器保持較好的通信質(zhì)量,在協(xié)議中規(guī)定對(duì)用戶設(shè)備 與讀寫器間建立的通信信道的可靠性進(jìn)行實(shí)時(shí)的校驗(yàn)。即在對(duì)讀寫器進(jìn)行復(fù)位啟動(dòng)后,還需要在用戶端與讀寫器間進(jìn)行一個(gè)稱為通信“握手”的校驗(yàn)程序,目的在于檢驗(yàn)當(dāng)前通信信道的工作狀態(tài)是否正常。其具體內(nèi)容主要是對(duì)
8、一組預(yù)定義的數(shù)據(jù),在用戶端與讀寫器之間進(jìn)行通信傳輸,通過驗(yàn)證通信結(jié)果是否符合預(yù)設(shè)的數(shù)據(jù)內(nèi)容,校驗(yàn)當(dāng)前通信信道是否正確可靠。通常為用戶發(fā)送第一響應(yīng)碼至讀寫器,讀寫器正確接收到則返回第二響應(yīng)碼至用戶端,而用戶端若正確接收到第二響應(yīng)碼則繼續(xù)下一步工作,否則等待讀寫器端重發(fā)數(shù)據(jù)。但如果在限時(shí)內(nèi)未收到正確的第二響應(yīng)碼數(shù)據(jù)則確認(rèn)為當(dāng)前通信出現(xiàn)異常,并提示系統(tǒng)報(bào)告當(dāng)前錯(cuò)誤情況。 3.3 指令格式 讀寫器的用戶在與讀寫器進(jìn)行數(shù)據(jù)通信時(shí),根據(jù)智能卡應(yīng)用規(guī)范,用戶端都應(yīng)當(dāng)遵循一定的 格式組織和創(chuàng)建指令及提供所需的相關(guān)數(shù)據(jù),目前在讀寫器的控制與使用協(xié)議中定義并使用了以下的一種指令格式。 指令由 5 個(gè)基本字節(jié)組成:
9、字節(jié) 1:CLA,指令標(biāo)識(shí)符一;字節(jié)2:INS,指令標(biāo)識(shí)符二;字節(jié)3,4:P1和P2,指令參數(shù);字節(jié) 5:LC,數(shù)據(jù)長度。 用戶端依據(jù)這樣格式建立和發(fā)送指令序列至讀寫器,其中字節(jié)1和字節(jié)2形成一個(gè)二級(jí)的指令標(biāo)識(shí),說明當(dāng)前指令操作碼的含義;字節(jié)3和字節(jié)4提供一個(gè)參數(shù)空間,輔助說明指令操作碼;字節(jié) 5 說明當(dāng)前指令操作數(shù)的數(shù)據(jù)長度,主要是針對(duì)于非定長數(shù)據(jù)的通信傳輸過程。 3.4 操作流程 在用戶實(shí)際使用讀寫器操作智能卡的過程中,絕大部分操作都是在完成一個(gè)由用戶端發(fā)送指令和數(shù)據(jù)至讀寫器,由讀寫器解釋執(zhí)行并轉(zhuǎn)發(fā)至智能卡,最后由智能卡端返回結(jié)果至讀寫器,讀寫器最終返回至用戶端的一個(gè)操作過程。因此也以他作
10、為主要依據(jù)來規(guī)范相關(guān)的軟件協(xié)議,具體如下所示: 復(fù)位啟動(dòng)讀寫器協(xié)議要求中的第一步工作。 通信“握手”為確保通信過程的正確有效,用戶與讀寫器進(jìn)行數(shù)據(jù)通信 前都將要先進(jìn)行這一步工作。 發(fā)送指令用戶向讀寫器發(fā)送操作指令時(shí),指令組建必須要符合協(xié)議中的 規(guī)定格式。 發(fā)送數(shù)據(jù)對(duì)于含有操作數(shù)的指令,在送出指令碼后,還必須將相關(guān)的 數(shù)據(jù)送至讀寫器。 接收狀態(tài)碼讀寫器在接收到并執(zhí)行用戶指令后,會(huì)根據(jù)執(zhí)行結(jié)果的內(nèi)容返回執(zhí)行狀態(tài)碼和結(jié)果數(shù)據(jù)至 PC 機(jī),由此用戶可得到指令的執(zhí)行結(jié)果。 接收數(shù)據(jù)如果當(dāng)前用戶指令要求讀寫器提供結(jié)果數(shù)據(jù),讀寫器在返回執(zhí)行狀態(tài)碼后,需繼續(xù)送結(jié)果數(shù)據(jù)至PC機(jī)。根據(jù)協(xié)議,結(jié)果數(shù)據(jù)的長度由指令碼中的LC字節(jié)說明。 4 對(duì)智能卡的操作 COS 命令接口 讀寫器作為用戶端與 IC 卡間的操作平臺(tái),在接受用戶端控制與使用的同時(shí),還有一個(gè)重要的 功能就是實(shí)現(xiàn)對(duì)智能卡的操作。COS 命令接口就是對(duì)智能卡操作的前端實(shí)現(xiàn)部分。通常在智能卡應(yīng)用當(dāng)中,智能卡本身都具備一個(gè) COS 系統(tǒng),由他協(xié)調(diào)并控制卡上的所有指令和數(shù)據(jù)處理過程,讀寫器必須借助于 COS 系統(tǒng)才能夠?qū)崿F(xiàn)相應(yīng)的功能。COS 命令接口做為讀寫器端的 CO S 數(shù)據(jù)通道直接影響到讀寫器對(duì)卡的操作。在這一部分協(xié)議中規(guī)定讀寫器向IC卡發(fā)送一組
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 安裝合同匯編3篇
- 擺脫缺陷責(zé)任書3篇
- 教育培訓(xùn)課程委托3篇
- 文明進(jìn)步承諾3篇
- 工程小修施工協(xié)議3篇
- 教育機(jī)構(gòu)培訓(xùn)師雇傭合同范本3篇
- 工傷保險(xiǎn)授權(quán)委托書范本3篇
- 商業(yè)綜合體幕墻改造合同
- 西安市精裝房買賣合同樣本
- 獵頭合作協(xié)議書范例
- 2025版寒假特色作業(yè)
- Unit 7 Will people have robots Section B 1a-1e 教學(xué)實(shí)錄 2024-2025學(xué)年人教版英語八年級(jí)上冊(cè)
- 國內(nèi)外航空安全形勢
- 《雷達(dá)原理》課件-1.1.6教學(xué)課件:雷達(dá)對(duì)抗與反對(duì)抗
- 微信小程序云開發(fā)(赤峰應(yīng)用技術(shù)職業(yè)學(xué)院)知到智慧樹答案
- 遼寧省撫順市清原縣2024屆九年級(jí)上學(xué)期期末質(zhì)量檢測數(shù)學(xué)試卷(含解析)
- 2024-2025學(xué)年上學(xué)期福建高二物理期末卷2
- 2024四川阿壩州事業(yè)單位和州直機(jī)關(guān)招聘691人歷年管理單位遴選500模擬題附帶答案詳解
- 麻醉科工作計(jì)劃
- 四川省2023年普通高中學(xué)業(yè)水平考試物理試卷 含解析
- 【MOOC】中級(jí)財(cái)務(wù)會(huì)計(jì)-北京交通大學(xué) 中國大學(xué)慕課MOOC答案
評(píng)論
0/150
提交評(píng)論