DES加密解密,满满干货指导

这篇文章详细介绍了DesUtils类,一个用于在Android中实现DES加密(DES/CBC/PKCS5Padding模式)的工具,包括密钥生成、二进制转字符、加密和解密操作。它着重于DES算法在移动开发中的实际应用和注意事项。
摘要由CSDN通过智能技术生成

break;

}

}

}

DesUtils

import android.util.Base64;

import java.security.Key;

import java.security.SecureRandom;

import javax.crypto.Cipher;

import javax.crypto.KeyGenerator;

import javax.crypto.SecretKey;

import javax.crypto.spec.IvParameterSpec;

import javax.crypto.spec.SecretKeySpec;

/**

  • Created by Administrator on 2017/9/20 0020.

*/

public class DesUtils {

//至少16位

private final static String HEX = “huangxiaoguo1234”;

//DES是加密方式 CBC是工作模式 PKCS5Padding是填充模式

private final static String TRANSFORMATION = “DES/CBC/PKCS5Padding”;

//初始化向量参数,AES 为16bytes. DES 为8bytes,只能8位

private final static String IVPARAMETERSPEC = “xiao_guo”;

//DES是加密方式

private final static String ALGORITHM = “DES”;

// SHA1PRNG 强随机种子算法, 要区别4.2以上版本的调用方法

private static final String SHA1PRNG = “SHA1PRNG”;

/**

  • 生成随机数,可以当做动态的密钥 加密和解密的密钥必须一致,不然将不能解密

  • @return

*/

public static String generateKey() {

try {

SecureRandom localSecureRandom = SecureRandom.getInstance(SHA1PRNG);

byte[] bytes_key = new byte[20];

localSecureRandom.nextBytes(bytes_key);

String str_key = toHex(bytes_key);

return str_key;

} catch (Exception e) {

e.printStackTrace();

}

return null;

}

/**

  • 二进制转字符

  • @param buf

  • @return

*/

public static String toHex(byte[] buf) {

if (buf == null)

return “”;

StringBuffer result = new StringBuffer(2 * buf.length);

for (int i = 0; i < buf.length; i++) {

appendHex(result, buf[i]);

}

return result.toString();

}

private static void appendHex(StringBuffer sb, byte b) {

sb.append(HEX.charAt((b >> 4) & 0x0f)).append(HEX.charAt(b & 0x0f));

}

/**

  • 对密钥进行处理

  • @param key

  • @return

  • @throws Exception

*/

private static Key getRawKey(String key) throws Exception {

KeyGenerator kgen = KeyGenerator.getInstance(ALGORITHM);

//for android

SecureRandom sr = null;

// 在4.2以上版本中,SecureRandom获取方式发生了改变

if (android.os.Build.VERSION.SDK_INT >= 17) {

sr = SecureRandom.getInstance(SHA1PRNG, “Crypto”);

} else {

sr = SecureRandom.getInstance(SHA1PRNG);

}

// for Java

// secureRandom = SecureRandom.getInstance(SHA1PRNG);

sr.setSeed(key.getBytes());

kgen.init(64, sr); //DES固定格式为64bits,即8bytes。

SecretKey skey = kgen.generateKey();

byte[] raw = skey.getEncoded();

return new SecretKeySpec(raw, ALGORITHM);

}

/**

  • 第二种对密钥进行处理

*/

// private static Key getRawKey(String key) throws Exception {

// DESKeySpec dks = new DESKeySpec(key.getBytes());

// SecretKeyFactory keyFactory = SecretKeyFactory.getInstance(ALGORITHM);

// return keyFactory.generateSecret(dks);

// }

/**

  • DES算法,加密

  • @param data 待加密字符串

  • @param key 加密私钥,长度不能够小于8位

  • @return 加密后的字节数组,一般结合Base64编码使用

*/

public static String encode(String key, String data) {

return encode(key, data.getBytes());

}

/**

  • DES算法,加密

  • @param data 待加密字符串

  • @param key 加密私钥,长度不能够小于8位

  • @return 加密后的字节数组,一般结合Base64编码使用

*/

public static String encode(String key, byte[] data) {

try {

Cipher cipher = Cipher.getInstance(TRANSFORMATION);

IvParameterSpec iv = new IvParameterSpec(IVPARAMETERSPEC.getBytes());

cipher.init(Cipher.ENCRYPT_MODE, getRawKey(key), iv);

byte[] bytes = cipher.doFinal(data);

return Base64.encodeToString(bytes, Base64.DEFAULT);

} catch (Exception e) {

return null;

}

}

/**

  • 获取编码后的值

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级安卓工程师,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新Android移动开发全套学习资料》送给大家,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img
img

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频
如果你觉得这些内容对你有帮助,可以添加下面V无偿领取!(备注Android)
img

如何成为Android高级架构师!

架构师必须具备抽象思维和分析的能力,这是你进行系统分析和系统分解的基本素质。只有具备这样的能力,架构师才能看清系统的整体,掌控全局,这也是架构师大局观的形成基础。 你如何具备这种能力呢?一是来自于经验,二是来自于学习。

架构师不仅要具备在问题领域上的经验,也需要具备在软件工程领域内的经验。也就是说,架构师必须能够准确得理解需求,然后用软件工程的思想,把需求转化和分解成可用计算机语言实现的程度。经验的积累是需要一个时间过程的,这个过程谁也帮不了你,是需要你去经历的。

但是,如果你有意识地去培养,不断吸取前人的经验的话,还是可以缩短这个周期的。这也是我整理架构师进阶此系列的始动力之一。


成为Android架构师必备知识技能

对应导图的学习笔记(由阿里P8大牛手写,我负责整理成PDF笔记)

部分内容展示

《设计思想解读开源框架》

  • 目录
  • 热修复设计
  • 插件化框架设计

    《360°全方面性能优化》
  • 设计思想与代码质量优化
  • 程序性能优化

图片转存中…(img-iHipbeF1-1711180663407)]

  • 热修复设计
    [外链图片转存中…(img-hDJHpids-1711180663407)]
  • 插件化框架设计
    [外链图片转存中…(img-Tit9ynKa-1711180663408)]
    《360°全方面性能优化》
    [外链图片转存中…(img-FoWNtuMw-1711180663408)]
  • 设计思想与代码质量优化
    [外链图片转存中…(img-KLHVbCR3-1711180663408)]
  • 程序性能优化
    [外链图片转存中…(img-IpHj32EU-1711180663409)]

本文在开源项目:【GitHub 】中已收录,里面包含不同方向的自学编程路线、面试题集合/面经、及系列技术文章等,资源持续更新中…

  • 21
    点赞
  • 30
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值