一種運行大容量USIM小應用程式的方法與流程
2023-09-15 05:18:10
本發明涉及集成電路大容量usim卡領域,尤其涉及一種運行大容量usim小應用程式方法。
背景技術:
在當今這個通訊技術發達的時代,usim卡作為移動通訊設備中用戶身份識別的產品,已經普遍應用,但是由於usim的存儲空間有限,無法預裝過多的小應用程式,所以當需要安裝或執行一個usim上沒有的小應用程式時,就需要採用空中下載或到營業廳現場下載的方式,這種方式造成廣大用戶的使用不方便。
但是,大容量usim擁有海量存儲空間,可以將相當數量的小應用程式預置到大容量usim中,一旦需要在javacard(爪哇卡)平臺上安裝任何一個已經存儲在海量存儲空間內的小應用程式時,大容量usim無需通過行動網路下載或在營業廳進行安裝,直接從海量存儲空間內獲取已經預存儲的小應用程式,並在大容量usim內運行,實現了離線安裝,同時也擴展了usim的應用功能,這給予廣大用戶使用便利。
技術實現要素:
本發明旨在提供一種運行大容量usim小應用程式的方法,由於具有較大空間的海量存儲區,大容量usim可以預下載多個小應用程式,當需要安裝或調用時,可從海量存儲區內讀取小應用程式,將這些小應用程式安裝到大容量usim內執行。
本發明涉及一種運行大容量usim小應用程式方法,包括存儲小應用程式階段和執行小應用程式階段兩個部分,其中,所述存儲小應用程式階段是將小應用程式通過通訊接口下載到大容量usim中,並在海量存儲空間內的智慧卡分區進行存儲,其具體實現步驟如下:
1)大容量usim支持iso/iec7816和usb通訊接口,若與生產設備或手機終端等主機的iso/iec7816接口連接後,大容量usim將持續在接觸式通訊接口上與主機進行數據交互;若與生產設備、手機終端或工作計算機等主機的usb接口連接後,大容量usim將持續在usb通訊接口上、以ccid協議與主機進行數據交互;
2)一旦成功連接了接觸式通訊接口或usbccid通訊接口,主機便可通過指令訪問大容量usim的海量存儲空間中的智慧卡分區;
3)主機向大容量usim發送下載指令,將多個小應用程式存儲到海量存儲空間內的智慧卡分區;
4)如果大容量usim為javacard(爪哇卡),主機將使用gp(globalplatform,致力於開發、制定並發布安全晶片的技術標準的跨行業的國際標準組織)規範中的標準下載指令,將javaapplet寫入智慧卡分區;
5)如果大容量usim為nativecard(本地卡),主機將使用雙方均可識別的私有下載指令,將小應用程式代碼寫入智慧卡分區;
其中,所述執行小應用程式階段是將小應用程式從海量存儲空間的智慧卡分區內讀取出來,並在大容量usim的片上作業系統的運行空間內裝載和運行,其具體實現步驟如下:
1)若大容量usim為javacard(爪哇卡):
a)主機將向大容量usim發送gp(globalplatform)規範中的安裝指令;
b)大容量usim將訪問海量存儲空間內的智慧卡分區,通過檢索應用標識找到所要安裝的小應用程式,並將小應用程式從智慧卡分區中讀取到大容量usim片上作業系統內;
c)主機發送gp(globalplatform)規範中的激活指令,來選中小應用程式,大容量usim片上作業系統將會在其運行空間上,如nvm(non-volatilememory,非易失性存儲器)或ram(random-accessmemory,隨機訪問存儲器),執行被選中的小應用程式;
d)當主機發送gp(globalplatform)規範中的去激活或卸載指令,在大容量usim片上作業系統的運行空間內執行的小應用程式,將被停止、註銷或刪除,而在海量存儲空間的智慧卡分區內依然存儲著未被安裝的小應用程式;
2)若大容量usim為nativecard(本地卡):
a)主機將向大容量usim發送執行小應用程式的私有指令;
b)大容量usim將訪問海量存儲空間內的智慧卡分區,通過檢索應用標識找到所要被調用的小應用程式,並將小應用程式從智慧卡分區中讀取到大容量usim片上作業系統內;
c)大容量usim片上作業系統將會在其運行空間上,如nvm(non-volatilememory,非易失性存儲器)或ram(random-accessmemory,隨機訪問存儲器),執行小應用程式;
d)當主機發送應用結束指令,在大容量usim片上作業系統的運行空間內執行的小應用程式,將被停止並從片上作業系統內刪除,而在海量存儲空間的智慧卡分區內依然存儲著未被讀取的小應用程式。
優選地,所述大容量usim為用戶識別卡,既支持傳統電信業務,又支持海量存儲功能。
優選地,所述大容量usim支持iso/iec7816和usb(universalserialbus,通用串行總線)兩種通訊接口,並通過這兩種通訊接口訪問到海量存儲空間不同分區。
優選地,所述大容量usim為usb複合設備,在連接手機終端或工作計算機等主機的usb接口後,作為從設備可被識別為ccid(usbchip/smartcardinterfacedevices,usb晶片智慧卡接口設備)和具有多個存儲器分區的usb海量存儲設備。
優選地,所述大容量usim,其中,所述海量存儲功能,是指該大容量usim具有多個存儲分區,各個存儲分區都有不同的訪問權限和應用功能,其中一個存儲分區作為智慧卡分區,提供給電信業務功能進行訪問,小應用程式將存儲在智慧卡分區內。
優選地,所述大容量usim片上作業系統為大容量usim內運行作業系統,該片上作業系統有兩種實現方式,一種是javacard(爪哇卡)平臺,另一種是nativecard(本地卡)平臺。
優選地,所述javacard(爪哇卡)平臺以javacard(爪哇卡)平臺規格(javacardplatformspecifications)為標準實現,提供標準的應用功能接口,並且任何小應用程式在javacard(爪哇卡)平臺上運行時,調用不同的標準應用功能接口來完成目標操作,使得同一張usim實現不同的應用功能。
優選地,所述nativecard(本地卡)平臺沒有統一的實現標準,其平臺與小應用程式之間的連接為固定接口,並且在nativecard(本地卡)平臺上只能運行若干個固定的小應用程式,這張usim只能實現若干個固定的應用功能。
優選地,所述的小應用程式是javacard(爪哇卡)上運行的javaapplet小應用程式,可以動態地在javacard(爪哇卡)平臺上進行下載、安裝、激活、反激活和卸載操作,在被激活後,小應用程式即可接收外部發送的命令,並執行小應用程式的相應代碼。
優選地,所述小應用程式是nativecard(本地卡)平臺上運行的若干個固定的小應用程式,不需要下載、安裝或激活,通過nativecard(本地卡)平臺對接收到的外部命令進行處理,直接調用小應用程式的相應接口或代碼,實現該應用的功能。
優選地,所述存儲小應用程式階段,生產設備或工作計算機等主機可以通過iso/iec7816或usbccid接口與大容量usim進行連接,通過這些接口可以訪問到海量存儲區內的智慧卡分區,使用下載指令將小應用程式寫入到智慧卡分區內,並通過不同的應用標籤,區分為不同的小應用程式所存儲的位置。
優選地,所述執行小應用程式階段,大容量usim從iso/iec7816或usbccid接口接收到主機發送的指令,要求安裝或調用某一個小應用程式,此時大容量usim片上作業系統將從大容量usim的海量存儲空間的智慧卡分區內檢索應用標籤,讀出小應用程式,並將這一小應用程式安裝在大容量usim的運行空間內,在javacard(爪哇卡)平臺或nativecard(本地卡)平臺上執行。
本發明由於採用了上述存儲小應用程式階段和執行小應用程式階段,所獲得的有益效果是,通過行動網路下載或在營業廳進行安裝,直接從海量存儲空間內獲取已經預存儲的小應用程式,並在大容量usim內運行,實現了離線安裝,同時也擴展了usim的應用功能,這給予廣大用戶使用便利。
下面結合附圖和具體實施方式對本發明做進一步說明。
附圖說明
圖1是本發明具體實施的大容量usim實現為javacard(爪哇卡)的存儲和執行階段的工作流程圖。
圖2是本發明具體實施的大容量usim實現為nativecard(本地卡)的存儲和執行階段的工作流程圖。
具體實施方式
如圖1所示,為本發明具體實施的大容量usim實現為javacard(爪哇卡)的存儲和執行階段的工作流程圖;該大容量usim實現為javacard(爪哇卡)的存儲和執行階段具體步驟如下:(1)小應用程式的生命周期從開始下載到大容量usim的智慧卡分區開始;(2)首先大容量卡與主機連接,建立接口通道;(3)主機在iso/iec7816或usbccid接口上發送gp(globalplatform)的下載指令;(4)在下載過程中,小應用程式會被分配應用標識,與小應用程式一起寫入;(5)將小應用程式寫入到大容量usim的智慧卡分區內;(6)是否完成下載?在完成所有的下載操作後,小應用程式就會儲存在智慧卡分區中,即使大容量usim失去供電電源也會一直保存,這通常是在大容量usim的生產階段發生的;(7)上述步驟,完成下載情況下,在大容量usim在客戶端應用時,當接收到外部發來的gp(globalplatform)安裝指令,要求安裝小應用程式;(8)那麼,大容量usim的片上作業系統將在智慧卡分區內檢索小應用程式的應用標識;(9)檢索到應用標識之後,就會讀取該javaapplet到片上作業系統;(10)然後將javaapplet寫入到大容量usim的運行空間(nvm或者ram),並暫存到該運行空間中;(11)大容量usim接收到了gp(globalplatform)激活指令;(12)該javaapplet小應用程式就會被執行,並響應後續所接收到的相關指令;(13)若主機所發送的指令是gp(globalplatform)去激活或卸載指令?(14)如果是上述指令,那麼,該javaapplet小應用程式就會從運行空間中被註銷並刪除;(15)結束,但該javaapplet小應用程式的代碼不會從智慧卡分區內刪除。
如圖2所示,本發明具體實施的大容量usim實現為nativecard(本地卡)的存儲和執行階段的工作流程圖;該大容量usim實現為nativecard(本地卡)的存儲和執行階段具體步驟如下:(1)開始,由於nativecard(本地卡)並非國際通用的標準平臺機制,所以在數據交互過程中所發送的指令均為主機與大容量usim相互承認的私有指令;(2)首先大容量usim與主機(iso/iec7816或usbccid接口)連接,建立接口通道;(3)主機在iso/iec7816或usbccid接口上私有下載指令;(4)通過給小應用程式分配應用標識來區分不同的小應用程式代碼;(5)將小應用程式寫入到大容量usim的智慧卡分區內;(6)是否完成下載?在完成小應用程式的下載步驟後,智慧卡分區中就保存;(7)當大容量usim接收到外部發來的調用小應用程式的指令;(8)在完成上述下載情況下,大容量usim的片上作業系統將在智慧卡分區內檢索小應用程式的應用標識;(9)檢索到該應用標識之後,讀取出該小應用程式的代碼到片上作業系統;(10)將該小應用程式寫入大容量usim的運行空間;(11)保存該小應用程式於運行空間中,並被調用執行;(12)若主機向大容量usim發送了應用終止的私有指令,即不再需要調用該小應用程式;(13)如果不再調用該小應用程式,那麼就會從大容量usim片上作業系統的運行空間中被刪除掉;(14)結束,但該小應用程式依然會存留在智慧卡分區內,等待下次被調用。
以上是對本發明的較佳實施例進行了具體說明,但本發明並不限於所述的實施例,熟悉本領域的技術人員在不違背本發明目的和精神的前提下還可以做出各種等同或者替換,這些等同或者替換的,顯而易見形成的技術方案均應包括在本發明的權利要求所限定的範圍之內。