当前位置: 首页 > 编程笔记 >

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

国胤
2023-03-14
本文向大家介绍快速搞懂Android口令加密(一),包括了快速搞懂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口令加密的相关介绍,希望对大家有所帮助!

 类似资料:
  • 本文向大家介绍搞懂Java线程池,包括了搞懂Java线程池的使用技巧和注意事项,需要的朋友参考一下 身为程序员我们对线程是再熟悉不过了,多线程并发算是Java进阶的知识,用好多线程不容易有太多的坑。创建线程也算是一个"重"操作。创建线程的语句是new Thread()咋一看好像就是new了一个对象。 没错是new了个对象,但是不仅仅是普通对象那样在堆中分配了一块内存,它还需要调用操作系统内核API

  • 问题内容: 我对Swift还是比较陌生,我无法使用HMAC和SHA1进行加密 问题答案: 问题解决了!首先,我没有正确使用字符串函数…我最终得到了: 然后我忘记了我需要对hmac结果进行base64编码。所以我将问题中链接的字符串函数修改为… 这给了我正确的结果

  • 本文向大家介绍一文搞懂JAVA 枚举(enum),包括了一文搞懂JAVA 枚举(enum)的使用技巧和注意事项,需要的朋友参考一下 Java 枚举是一个特殊的类,一般表示一组常量,比如一年的 4 个季节,一个年的 12 个月份,一个星期的 7 天,方向有东南西北等。 Java 枚举类使用 enum 关键字来定义,各个常量使用逗号 , 来分割。 例如定义一个颜色的枚举类。 以上枚举类 Color 颜

  • 问题内容: 我尝试使用AES 128位密钥解密4.2 MB .dcf文件,但是解密(在cipher.doFinal(data)函数上)花费了33秒,这是否正常? 这是一个代码片段: 问题答案: 您应该尝试计算不写入文件所花费的时间,即,在调用之前和之后立即调用。 话虽这么说,基于Android的手机通常使用最新的主频为500 MHz或更高的ARM处理器,并且从理论上讲,这种野兽每秒可以对几兆字节的

  • 大家好,今天给大家介绍一个非常热门的技术,同时也是面试的时候面试官特别喜欢问的一个话题,那就是 SpringCloudAlibaba 的底层原理。 现在大家都知道,SpringCloudAlibaba 风靡 Java 开发行业,各个公司都在用这套技术,所以咱们 Java 工程师出去面试,面试官对 SpringCloudAlibaba 都搞成了面试必问选项了,但凡面试,总会有面试官问问:“兄弟,Sp

  • 我试图理解谷歌GCM快速入门示例背后的代码。具体来说,我不明白代码是如何检查注册是否已经完成的。 主要活动: 注册意向服务: 在中,注释说最初调用是为了检索令牌,但随后的调用是本地的。这是否意味着它会简单地检查应用程序是否已经拥有令牌,不再进行调用?我真的不明白这部分,我在这个示例代码中没有看到它检查令牌存在的任何地方。