
2010年11月23日
KEY采用的是求一個字符串的SHA1值(160bit)賦給一個int型數組int KEY[5]作為OTP生成方法的的參數輸入。輸入的字符串不可以超過16,通過判斷字符串長度提醒用戶輸入的KEY是否合法。將輸入的字符串通過Tochar方法法轉換成一個16元素的char型數組,然后再轉換成一個整形數組,對于長度小于16的空余元素則補零。調用SHA1類中的dofinal方法產生160bit數據作為一個5元素的int型數組作為OTP參數。
posted @
2010-11-23 12:28 趙朋川 閱讀(289) |
評論 (0) |
編輯 收藏
OTP的counter為一個long型64位數據,每次產生一個新OTP后,counter值做自加一處理。此程序的counter采用android中輕量級存儲sharedpreference進行保存。首先建立存儲文件夾,在文件夾下建立名為COUNTER的存儲變量,在調用OTP產生程序時,首先將COUNER的值從文件夾中讀出,為一個String類型,利用命令Long.parseLong()方法將其轉換為long型整數作為OTP程序的參數參與運算,然后COUNTER自加,轉換成String類型后保存到輕量級存儲文件夾中的COUNTER內,為下次調用準備。
在重置counter的程序中,將TextView中的值利用gettext()命令讀出,利用toString命令轉換成String類型后存儲在COUNTER中。對于輸入的整數值不能超過Long型整數的范圍,在存儲之前需要對輸入的整數進行相關判斷:將輸入的整數前面補零和2的64次方減一(18446744073709551615)進行字符串比較,如果輸入的整數大或者字符串長度超過20則提醒用戶輸入錯誤,重新輸入。
posted @
2010-11-23 12:17 趙朋川 閱讀(145) |
評論 (0) |
編輯 收藏