編輯:關於Android編程
廢話不多說了,直接給大家貼代碼了。
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 { /* * 基於口令加密創建步驟 * 1、讀取口令 * 將需加密字符串轉化為字符數組 * 將口令保存至PBEKeySpec對象中 * 2、由口令生成秘鑰 * 通過SecretKeyfactory工廠類的getInstance靜態方法獲取SecretKeyFactory對象; * getInstance方法需要一個參數--指定口令加密算法{ * 1、PBEWithMD5AndDES * 2、PBEWithHmacSHA1AndDESede} * 通過SecretKeyFactory工廠類的generateSecret()方法生成秘鑰 * 3、生成隨機數(鹽) * 鹽必須是8個元素的字節數組 * 通過Random類的nextbyte方法生成隨機數並將隨機數賦值給byte數組,參數為byte數組 * 4、創建並初始化密碼器 * 通過getInstance方法獲取密碼器對象,參數為基於口令的加密算法 * 通過PBEParameterSpec類構造器向Cipher對象指定基於口令加密的算法(包括提高破解難度的鹽) * 5、獲取明文,進行加密 * 執行密碼器的doFinal()方法進行加密,加密結果保存在字節數組ctext中 * */ //口令加密操作方法 public byte[] cmdEncryptionOperation(String encryptionStr,String pwdStr) throws Exception { //讀取口令 //將口令轉化為字符數組 char[] pwd = pwdStr.toCharArray(); //將加密數組存儲至PBEKeySpec對象 PBEKeySpec pbeKeySpec = new PBEKeySpec(pwd); //由口令生成秘鑰 //通過SecretKeyFactory的getinstance方法創建SecretKeyFactory對象,構造參數為加密類型 SecretKeyFactory secretKeyFactory = SecretKeyFactory .getInstance("PBEWithMD5AndDES");//拋出沒找到關鍵字異常 //通過generateSecret生成口令 SecretKey key = secretKeyFactory.generateSecret(pbeKeySpec); //生成隨機數(鹽) // 創建是8個元素的字節數組的鹽 byte[] salt = new byte[8]; //通過Random類的nextbyte方法生成隨機數並將隨機數賦值給byte數組,參數為byte數組 Random random = new Random(); random.nextBytes(salt); //創建並初始化密碼器 Cipher cipher = Cipher.getInstance("PBEWithMD5AndDES"); PBEParameterSpec parameterSpec = new PBEParameterSpec(salt, 1000); cipher.init(Cipher.ENCRYPT_MODE, key,parameterSpec); //獲取明文,進行加密 byte[] ptext = encryptionStr.getBytes("UTF-8"); byte[] ctext = cipher.doFinal(ptext);//cipher的dofinal方法進行加密 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]); } }
以上內容是針對Android口令加密的相關介紹,希望對大家有所幫助!
1.問題是如何發生的,會在什麼情況下發生此類問題?當用戶運用手機清理助手或後台回收我們的應用造成我們應用程序進程被殺死的時候就有可能出現這種空指針的問題,下面舉個例子我們
SearchView是搜索框組件,它可以讓用戶在文本框裡輸入文字,通過監聽器取得用戶的輸入,當用戶點擊搜索時,監聽器執行實際的搜索。本文就為大家分享了SearchView
我們要實現的目標是:做一個短信發送器 界面: 因為要涉及到短信發送這種屬於隱私的問題,所以我們要在AndroidManifest.xml中添加一行代碼,來獲得權限: 然
二維碼掃描 Android Zxing圖片拉伸解決 Zxing是google提供的二維碼掃描工程 默認是橫屏的 轉換成豎屏後圖片出現拉伸 這裡提供解決辦法: Zxi