KEY采用的是求一個(gè)字符串的SHA1值(160bit)賦給一個(gè)int型數(shù)組int KEY[5]作為OTP生成方法的的參數(shù)輸入。輸入的字符串不可以超過(guò)16,通過(guò)判斷字符串長(zhǎng)度提醒用戶(hù)輸入的KEY是否合法。將輸入的字符串通過(guò)Tochar方法法轉(zhuǎn)換成一個(gè)16元素的char型數(shù)組,然后再轉(zhuǎn)換成一個(gè)整形數(shù)組,對(duì)于長(zhǎng)度小于16的空余元素則補(bǔ)零。調(diào)用SHA1類(lèi)中的dofinal方法產(chǎn)生160bit數(shù)據(jù)作為一個(gè)5元素的int型數(shù)組作為OTP參數(shù)。
OTP的counter為一個(gè)long型64位數(shù)據(jù),每次產(chǎn)生一個(gè)新OTP后,counter值做自加一處理。此程序的counter采用android中輕量級(jí)存儲(chǔ)sharedpreference進(jìn)行保存。首先建立存儲(chǔ)文件夾,在文件夾下建立名為COUNTER的存儲(chǔ)變量,在調(diào)用OTP產(chǎn)生程序時(shí),首先將COUNER的值從文件夾中讀出,為一個(gè)String類(lèi)型,利用命令Long.parseLong()方法將其轉(zhuǎn)換為long型整數(shù)作為OTP程序的參數(shù)參與運(yùn)算,然后COUNTER自加,轉(zhuǎn)換成String類(lèi)型后保存到輕量級(jí)存儲(chǔ)文件夾中的COUNTER內(nèi),為下次調(diào)用準(zhǔn)備。
在重置counter的程序中,將TextView中的值利用gettext()命令讀出,利用toString命令轉(zhuǎn)換成String類(lèi)型后存儲(chǔ)在COUNTER中。對(duì)于輸入的整數(shù)值不能超過(guò)Long型整數(shù)的范圍,在存儲(chǔ)之前需要對(duì)輸入的整數(shù)進(jìn)行相關(guān)判斷:將輸入的整數(shù)前面補(bǔ)零和2的64次方減一(18446744073709551615)進(jìn)行字符串比較,如果輸入的整數(shù)大或者字符串長(zhǎng)度超過(guò)20則提醒用戶(hù)輸入錯(cuò)誤,重新輸入。