DES加密解密,34岁程序员年薪50w

本文详细描述了一个Android应用中的加密和解密功能,使用DES算法配合CBC模式和PKCS5Padding,以及SecureRandom生成密钥的过程。展示了如何使用DesUtils类进行字符串的加密和解密操作,以及与Base64编码的结合使用。
摘要由CSDN通过智能技术生成

}

@Override

public void onClick(View view) {

switch (view.getId()) {

case R.id.btn_encryption://加密

String encryptionString = encryptionContext.getText().toString().trim();

if (TextUtils.isEmpty(encryptionString)) {

Toast.makeText(mContext, “请输入加密内容”, Toast.LENGTH_SHORT).show();

return;

}

String encode = DesUtils.encode(key, encryptionString);

tvEncryption.setText(encode);

break;

case R.id.btn_decode://解密

String decodeString = tvEncryption.getText().toString().trim();

if (TextUtils.isEmpty(decodeString)) {

Toast.makeText(mContext, “请先加密”, Toast.LENGTH_SHORT).show();

return;

}

String decode = DesUtils.decode(key, decodeString);

tvDecode.setText(decode);

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;

}

}

/**

  • 获取编码后的值

  • @param key

  • @param data

  • @return

*/

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

return decode(key, Base64.decode(data, Base64.DEFAULT));

}

/**

  • DES算法,解密

  • @param data 待解密字符串

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

  • @return 解密后的字节数组

*/

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

try {

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

深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则近万的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

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

img

img

img

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:Android)

结尾

  • 腾讯T4级别Android架构技术脑图;查漏补缺,体系化深入学习提升

img

  • 一线互联网Android面试题含详解(初级到高级专题)

这些题目是今年群友去腾讯、百度、小米、乐视、美团、58、猎豹、360、新浪、搜狐等一线互联网公司面试被问到的题目。并且大多数都整理了答案,熟悉这些知识点会大大增加通过前两轮技术面试的几率

img

有Android开发3-5年基础,希望突破瓶颈,成为架构师的小伙伴,可以关注我

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

别Android架构技术脑图;查漏补缺,体系化深入学习提升

[外链图片转存中…(img-wruj4h2D-1712485770648)]

  • 一线互联网Android面试题含详解(初级到高级专题)

这些题目是今年群友去腾讯、百度、小米、乐视、美团、58、猎豹、360、新浪、搜狐等一线互联网公司面试被问到的题目。并且大多数都整理了答案,熟悉这些知识点会大大增加通过前两轮技术面试的几率

[外链图片转存中…(img-Sfr4mPhf-1712485770648)]

有Android开发3-5年基础,希望突破瓶颈,成为架构师的小伙伴,可以关注我

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值