安卓NFC開發(fā)學習筆記_第1頁
安卓NFC開發(fā)學習筆記_第2頁
安卓NFC開發(fā)學習筆記_第3頁
安卓NFC開發(fā)學習筆記_第4頁
安卓NFC開發(fā)學習筆記_第5頁
已閱讀5頁,還剩5頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權,請進行舉報或認領

文檔簡介

1、大家學習android開發(fā)建議首選android開發(fā)文檔,該文檔在你下載的sdk中,路徑:/sdk/docs/index.html目前NFC應用的大的框架上的理解:我使用的API LEVEL是19,支持的API有三個:android.nfc,android.nfc.cardemulator,android.nfc.techNFC在手機上的應用大體分為兩類:讀卡器和卡android.nfc.cardemulator接口是為NFC作為卡應用提供的接口,在較低版本的API上是沒有的android.nfc.tech,android.nfc接口是為NFC作為讀卡器應用提供的接口首先說作為卡,nfc有兩種

2、實現(xiàn)方式,一個是使用NFC芯片作為卡,另一個是使用SIM作為卡Figure 1. NFC card emulation with a secure element.至于從讀卡器發(fā)送的指令到底是傳遞到NFC芯片還是SIM由NFC Controler控制,圖中Secure Element是指SIM,Host-CPU指NFC芯片android提供HostApduService用于NFC芯片,OffHostApduService用于SIM芯片,傳遞方向在res/xml文件中通過AID來控制ps:Host-Based Card Emulator 簡稱為HCE代碼實現(xiàn):AndroidManifest.xm

3、l 中 配置service,因為作為卡實現(xiàn)的話,NFC功能是作為service存在的 res/xml/apduservice.xml 中配置service響應的AID 配置文件完成后編寫service的處理方法:NFCService需要繼承HostApduService,如果需要與Activity通信,建議采用廣播方式也可以自己實現(xiàn)觀察者模式,只是這樣就需要持有Activity的引用,感覺不太好NFCService.javapublic class NFCService extends HostApduService private Intent intent = new Intent(mun

4、ication.RECEIVER); Override public void onCreate() /啟動Acivity Intent i = new Intent(); i.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);/需要啟動的Activity不是當前Activity的時候需要用FLAG_ACTIVITY_NEW_TASK i.setAction(com.apdu.nfc); getApplication().startActivity(i); Toast.makeText(getApplicationContext(), Service啟動, Toa

5、st.LENGTH_LONG).show(); Override public byte processCommandApdu(byte commandApdu, Bundle extras) /當注冊的AID被選中后,后續(xù)指令被分發(fā)到這個處理函數(shù)中 byte sw = new byte(byte)0x90,(byte)0x00; byte response = new byte5; if (commandApdu0=(byte)0x00 &commandApdu1=(byte)0xA4& commandApdu2=(byte)0x04 & commandApdu4=(byte)0x07& c

6、ommandApdu5=(byte)0xF0) return sw; else /apdu處理邏輯 switch(commandApdu1) case (byte)0xA8: break; case (byte)0xAE: break; default: return sw; intent.putExtra(command, commandApdu); intent.putExtra(response, response); sendBroadcast(intent); /利用廣播與Activity通信 return response; /SW值需要包含在response中 Override

7、public void onDeactivated(int reason) if (reason=HostApduService.DEACTIVATION_DESELECTED) Toast.makeText(getApplicationContext(), 已選擇其它應用, Toast.LENGTH_LONG).show(); else Toast.makeText(getApplicationContext(), 連接斷開, Toast.LENGTH_LONG).show(); Override public void onDestroy() Toast.makeText(getAppli

8、cationContext(), Service關閉, Toast.LENGTH_LONG).show(); super.onDestroy(); 框架搭建好剩余的事情就很簡單了,apdu的處理邏輯在processCommandApdu方法中實現(xiàn)即可以上是Host-CPU方式的實現(xiàn),SIM方式,API介紹中說該方式?jīng)]有提供可供操作的API,也就是說Android不會監(jiān)聽SIM卡與讀卡器之間的通信所以NFCOffService 只需要實現(xiàn)onBind接口,這樣綁定該Service的Activity可以對NFCOffService進行有限操作public class NFCOffService e

9、xtends OffHostApduService Override public IBinder onBind(Intent intent) / TODO Auto-generated method stub return null; 上面沒有提到的就是,如果你需要使用NFC,需要在Manifest中申請NFC權限: 現(xiàn)在來說說NFC芯片作為讀卡器的應用場景以及實現(xiàn)android.nfc.tech,android.nfc接口是為NFC作為讀卡器應用提供的接口接口定義了三種Action Tags:ACTION_NDEF_DISCOVERED,ACTION_TECH_DISCOVERED,ACT

10、ION_TAG_DISCOVERED。當你在Manifest文件中將Activity的action-filter設置為這三個Tag中的一種或幾種時,NFC響應事件會按照如圖流程處理我的理解是ACTION_NDEF_DISCOVERED 是用于兩臺NFC手機之間傳輸文件的ACTION_TECH_DISCOVERED,ACTION_TAG_DISCOVERED才是用于NFC與卡進行通訊的所以開發(fā)第一步是在Manifest中配置你的Action: TECH_DISCOVERED還需要配置meta-data,meta-data的作用相當于補充說明或者一些配置信息nfc_tech_filter.xml

11、android.nfc.tech.IsoDep android.nfc.tech.NfcA android.nfc.tech.NfcB android.nfc.tech.NfcF android.nfc.tech.NfcV android.nfc.tech.Ndef android.nfc.tech.NdefFormatable android.nfc.tech.MifareClassic android.nfc.tech.MifareUltralight 當然API中說明你可以將多個tech寫在一個tech-list中,我做了嘗試,這樣做會引出一個問題,在程序未啟動的情況下當手機刷卡時不會自

12、動打開程序如果想要自動打開需要按照上面這種寫法,tech的個數(shù)可以根據(jù)你想要支持的卡類型進行調(diào)整配置完成后,可以開始編寫自己的Activity的java代碼了在onCreate方法中,需要獲取NfcAdapter的引用,從名字可以看出這是一個適配器 NfcAdapter nfcAdapter; PendingIntent pendingIntent; Override protected void onCreate(Bundle savedInstanceState) super.onCreate(savedInstanceState); setContentView(R.layout.pos

13、_main); dc = (Button)findViewById(R.id.button4DC); ecc = (Button)findViewById(R.id.button4ECC); qpboc = (Button)findViewById(R.id.button4QPBOC); logWindow=(TextView)findViewById(Rmunication4Financy); nfcAdapter=NfcAdapter.getDefaultAdapter(this); pendingIntent = PendingIntent.getActivity( this, 0, n

14、ew Intent(this, getClass().addFlags(Intent.FLAG_ACTIVITY_SINGLE_TOP), 0); onNewIntent(getIntent(); 這里使用PendingIntent,該Intent與普通的Intent不同的是它是有一個延遲啟動的功能,它啟動時會回調(diào)onNewIntent函數(shù),這樣能夠?qū)崿F(xiàn)NFC與Activity的交互pendingIntent = PendingIntent.getActivity(this, 0, new Intent(this, getClass().addFlags(Intent.FLAG_ACTIVIT

15、Y_SINGLE_TOP), 0);的含義是將Intent傳遞給this Activity在onPause與onResume中需要添加代碼 public void onPause() super.onPause(); nfcAdapter.disableForegroundDispatch(this); public void onResume() super.onResume(); nfcAdapter.enableForegroundDispatch(this, pendingIntent, FILTERS, TECHLISTS); enableForegroundDispatch的作用是

16、,當NFC事件發(fā)生時如果當前Activity不是注冊了NFC action-filter的Activity,手機會顯示注冊了NFC事件的Activity供用戶選擇如果當前Activity注冊了NFC action 則將事件優(yōu)先交由當前Activity處理。onNewIntent實現(xiàn): Override public void onNewIntent(Intent intent) Parcelable p = intent.getParcelableExtra(NfcAdapter.EXTRA_TAG); if (p=null) return; Tag nfcTag = (Tag)p; fina

17、l IsoDep isodep = IsoDep.get(nfcTag);/ final NfcA isodep = NfcA.get(nfcTag); final byte cmd = (byte) 0x00, / CLA Class (byte) 0xB4, / INS Instruction (byte) 0x04, / P1 Parameter 1 (byte) 0x00, / P2 Parameter 2 (byte) 0x00, / Le ; try isodep.connect(); byte reaponse=null; logWindow.append(00B4040000+

18、n); try reaponse = isodep.getHistoricalBytes(); logWindow.append(Util.bytes2HexString(reaponse)+n); reaponse =isodep.transceive(cmd); logWindow.append(Util.bytes2HexString(reaponse)+n); catch (IOException e) / TODO Auto-generated catch block e.printStackTrace(); catch (IOException e1) / TODO Auto-generated

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經(jīng)權益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
  • 6. 下載文件中如有侵權或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論