快速搞懂Android口令加密(一)
更新時(shí)間:2016年04月06日 13:57:33 作者:小搬運(yùn)工
這篇文章主要介紹了快速搞懂Android口令加密(一)的相關(guān)資料,需要的朋友可以參考下
廢話不多說(shuō)了,直接給大家貼代碼了。
import java.util.Random; import javax.crypto.Cipher; import javax.crypto.SecretKey; import javax.crypto.SecretKeyFactory; import javax.crypto.spec.PBEKeySpec; import javax.crypto.spec.PBEParameterSpec; public class Token { /* * 基于口令加密創(chuàng)建步驟 * 1、讀取口令 * 將需加密字符串轉(zhuǎn)化為字符數(shù)組 * 將口令保存至PBEKeySpec對(duì)象中 * 2、由口令生成秘鑰 * 通過(guò)SecretKeyfactory工廠類的getInstance靜態(tài)方法獲取SecretKeyFactory對(duì)象; * getInstance方法需要一個(gè)參數(shù)--指定口令加密算法{ * 1、PBEWithMD5AndDES * 2、PBEWithHmacSHA1AndDESede} * 通過(guò)SecretKeyFactory工廠類的generateSecret()方法生成秘鑰 * 3、生成隨機(jī)數(shù)(鹽) * 鹽必須是8個(gè)元素的字節(jié)數(shù)組 * 通過(guò)Random類的nextbyte方法生成隨機(jī)數(shù)并將隨機(jī)數(shù)賦值給byte數(shù)組,參數(shù)為byte數(shù)組 * 4、創(chuàng)建并初始化密碼器 * 通過(guò)getInstance方法獲取密碼器對(duì)象,參數(shù)為基于口令的加密算法 * 通過(guò)PBEParameterSpec類構(gòu)造器向Cipher對(duì)象指定基于口令加密的算法(包括提高破解難度的鹽) * 5、獲取明文,進(jìn)行加密 * 執(zhí)行密碼器的doFinal()方法進(jìn)行加密,加密結(jié)果保存在字節(jié)數(shù)組ctext中 * */ //口令加密操作方法 public byte[] cmdEncryptionOperation(String encryptionStr,String pwdStr) throws Exception { //讀取口令 //將口令轉(zhuǎn)化為字符數(shù)組 char[] pwd = pwdStr.toCharArray(); //將加密數(shù)組存儲(chǔ)至PBEKeySpec對(duì)象 PBEKeySpec pbeKeySpec = new PBEKeySpec(pwd); //由口令生成秘鑰 //通過(guò)SecretKeyFactory的getinstance方法創(chuàng)建SecretKeyFactory對(duì)象,構(gòu)造參數(shù)為加密類型 SecretKeyFactory secretKeyFactory = SecretKeyFactory .getInstance("PBEWithMD5AndDES");//拋出沒(méi)找到關(guān)鍵字異常 //通過(guò)generateSecret生成口令 SecretKey key = secretKeyFactory.generateSecret(pbeKeySpec); //生成隨機(jī)數(shù)(鹽) // 創(chuàng)建是8個(gè)元素的字節(jié)數(shù)組的鹽 byte[] salt = new byte[8]; //通過(guò)Random類的nextbyte方法生成隨機(jī)數(shù)并將隨機(jī)數(shù)賦值給byte數(shù)組,參數(shù)為byte數(shù)組 Random random = new Random(); random.nextBytes(salt); //創(chuàng)建并初始化密碼器 Cipher cipher = Cipher.getInstance("PBEWithMD5AndDES"); PBEParameterSpec parameterSpec = new PBEParameterSpec(salt, 1000); cipher.init(Cipher.ENCRYPT_MODE, key,parameterSpec); //獲取明文,進(jìn)行加密 byte[] ptext = encryptionStr.getBytes("UTF-8"); byte[] ctext = cipher.doFinal(ptext);//cipher的dofinal方法進(jìn)行加密 return ctext; } }
使用加密方法:
public static void main(String[] args) throws Exception { Token token = new Token(); byte[] ctext = token.cmdEncryptionOperation("加QQ群 499092562交流??!","2016/4/5"); FileOutputStream os = new FileOutputStream("PBEEnc.dat"); os.write(ctext); for (int i = 0; i < ctext.length; i++) { System.out.print(ctext[i]); } }
以上內(nèi)容是針對(duì)Android口令加密的相關(guān)介紹,希望對(duì)大家有所幫助!
您可能感興趣的文章:
- Java加密解密工具(適用于JavaSE/JavaEE/Android)
- Android實(shí)現(xiàn)短信加密功能(發(fā)送加密短信、解密本地短信)
- Android編程之MD5加密算法實(shí)例分析
- Android編程加密算法小結(jié)(AES、Base64、RAS加密算法)
- Android實(shí)用圖文教程之代碼混淆、第三方平臺(tái)加固加密、渠道分發(fā)
- Android AES加密工具類分享
- Android之RAS加密算法測(cè)試實(shí)例
- Android 加密解密字符串詳解
- android md5加密與rsa加解密實(shí)現(xiàn)代碼
- Android數(shù)據(jù)加密之Des加密詳解
相關(guān)文章
Android編程檢測(cè)手機(jī)錄音權(quán)限是否打開(kāi)的方法
這篇文章主要介紹了Android編程檢測(cè)手機(jī)錄音權(quán)限是否打開(kāi)的方法,涉及Android針對(duì)音頻操作的相關(guān)技巧與注意事項(xiàng),需要的朋友可以參考下2017-11-11

Android懸浮按鈕點(diǎn)擊返回頂部FloatingActionButton
這篇文章主要為大家詳細(xì)介紹了Android懸浮按鈕FloatingActionButton點(diǎn)擊回到頂部的實(shí)現(xiàn)代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
2017-02-02 
Android EditText監(jiān)聽(tīng)回車鍵并處理兩次回調(diào)問(wèn)題
這篇文章主要介紹了Android EditText監(jiān)聽(tīng)回車鍵并處理兩次回調(diào)問(wèn)題,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
2018-08-08 
Android 高仿微信轉(zhuǎn)賬金錢(qián)輸入框規(guī)則
這篇文章主要介紹了Android 高仿微信金錢(qián)輸入框規(guī)則的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
2016-12-12