快速搞懂Android口令加密(一)

快速搞懂Android口令加密(一),第1张

概述废话不多说了,直接给大家贴代码了。importjava.util.Random;importjavax.crypto.Cipher;importjavax.crypto.SecretKey;

废话不多说了,直接给大家贴代码了。

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口令加密的相关介绍,希望对大家有所帮助!

总结

以上是内存溢出为你收集整理的快速搞懂Android口令加密(一)全部内容,希望文章能够帮你解决快速搞懂Android口令加密(一)所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/web/1149478.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-31
下一篇 2022-05-31

发表评论

登录后才能评论

评论列表(0条)

保存