情节:
多功能设备板子的密码键盘的调试程序
需要android上进行密钥的3des和des加密用户密钥和主密钥,发送给密码键盘(8位密钥为des,16位为3des)(java的3des为24为密钥,这就要补位下面有提到)
这两个加密的原理我不知道,最近才用到一次,记录下使用的方法和注意的东西:
注意:在使用上调用的函数没什么区别这两个,只有一个不同,3des的密钥需要24位(c代码的话只要16位,所以需要补位,16位的密钥的前八位,组成24位),des的密钥需要8位(des加密,就不需要补位,和去掉密文的后八位),
而且如果用c代码解密的话,需要去掉密文的后八位,java库函数自动增加的,不然c代码没法解密。
使用代码:
package com.start.android.usbserial.tools;
import java.io.UnsupportedEncodingException;
import javax.crypto.Cipher;
import javax.crypto.SecretKey;
import javax.crypto.spec.SecretKeySpec;
import android.util.Log;
/**
* SecretUtils {3DES加密解密的工具类 }
*
* @author dengzt
* @date 2013-08-1
*/
public class SecretUtils {
// 定义加密算法,有DES、DESede(即3DES)、Blowfish
public static final String Algorithm3DES = "DESede";//0
public static final String AlgorithmDES = "DES";//1
//约定密钥
private static final byte[] FIX_KEY = { (byte) 0xFF,
(byte) 0xFF, (byte) 0xFF, (byte) 0xFF, (byte) 0xFF, (byte) 0xFF,
(byte) 0xFF, (byte) 0xFF, (byte) 0xFF, (byte) 0xFF, (byte) 0xFF,
(byte) 0xFF, (byte) 0xFF, (byte) 0xFF, (byte) 0xFF, (byte) 0xFF };
/**
* 使用约定密钥,加密方法 3des
* @param src
* @param Algorithm 算法
* @return
*/
public static byte[] encryptMode(byte[] src,String Algorithm) {
try {
SecretKey deskey = new SecretKeySpec(
Algorithm.equals(Algorithm3DES)?build3DesKey(FIX_KEY):build3DesKey(FIX_KEY), Algorithm); // 生成密钥
Cipher c1 = Cipher.getInstance(Algorithm);// 实例化负责加密/解密的Cipher工具类
c1.init(Cipher.ENCRYPT_MODE, deskey); // 初始化为加密模式
return c1.doFinal(src);
} catch (java.security.NoSuchAlgorithmException e1) {
e1.printStackTrace();
} catch (javax.crypto.NoSuchPaddingException e2) {
e2.printStackTrace();
} catch (java.lang.Exception e3) {
e3.printStackTrace();
}
return null;
}
/**
* 使用指定密钥的 加密
* @param src
* @param key 密钥
* @param Algorithm 算法
* @return
*/
public static byte[] encryptMode(byte[] src,byte[] key,String Algorithm) {
try {
SecretKey deskey = new SecretKeySpec(
Algorithm.equals(Algorithm3DES)?build3DesKey(key):build3DesKey(key), Algorithm); // 生成密钥
Cipher c1 = Cipher.getInstance(Algorithm);// 实例化负责加密/解密的Cipher工具类
c1.init(Cipher.ENCRYPT_MODE, deskey); // 初始化为加密模式
return c1.doFinal(src);
} catch (java.security.NoSuchAlgorithmException e1) {
e1.printStackTrace();
} catch (javax.crypto.NoSuchPaddingException e2) {
e2.printStackTrace();
} catch (java.lang.Exception e3) {
e3.printStackTrace();
}
return null;
}
/**
* 解密函数
*
* @param src
* 密文的字节数组
* @return
*/
public static byte[] decryptMode(byte[] src,String Algorithm) {
try {
SecretKey deskey = new SecretKeySpec(
build3DesKey(FIX_KEY), Algorithm);
Cipher c1 = Cipher.getInstance(Algorithm);
c1.init(Cipher.DECRYPT_MODE, deskey); // 初始化为解密模式
return c1.doFinal(src);
} catch (java.security.NoSuchAlgorithmException e1) {
e1.printStackTrace();
} catch (javax.crypto.NoSuchPaddingException e2) {
e2.printStackTrace();
} catch (java.lang.Exception e3) {
e3.printStackTrace();
}
return null;
}
/**
* 去掉java加密后会在后面自动填充的8位
* @param src
* @return
*/
public static byte[] withoutAutofill(byte[] src){
byte[] newbyte = new byte[src.length-8];
for(int i=0 ; i<newbyte.length;i++){
newbyte[i] = src[i];
}
return newbyte;
}
/*
* 根据字符串生成密钥字节数组
*
* @param keyStr 密钥字符串
*
* @return
*
* @throws UnsupportedEncodingException
*/
public static byte[] build3DesKey(byte[] temp)
throws UnsupportedEncodingException {
byte[] key = new byte[24]; // 声明一个24位的字节数组,默认里面都是0
System.arraycopy(temp, 0, key, 0, temp.length);
// 补充的8字节就是16字节密钥的前8位
for (int i = 0; i < 8; i++) {
key[16 + i] = temp[i];
}
return key;
}
/*
* 实现字节数组向十六进制的转换方法一
*/
public static String byte2HexStr(byte[] b) {
String hs = "";
String stmp = "";
for (int n = 0; n < b.length; n++) {
stmp = (Integer.toHexString(b[n] & 0XFF));
if (stmp.length() == 1)
hs = hs + "0" + stmp+" ";
else
hs = hs + stmp+" ";
}
return hs.toUpperCase();
}
/**
* Convert hex string to byte[]
* @param hexString the hex string
* @return byte[]
*/
public static byte[] hexStringToBytes(String hexString) {
if (hexString == null || hexString.equals("")) {
return null;
}
hexString = hexString.toUpperCase();
int length = hexString.length() / 2;
char[] hexChars = hexString.toCharArray();
byte[] d = new byte[length];
for (int i = 0; i < length; i++) {
int pos = i * 2;
d[i] = (byte) (charToByte(hexChars[pos]) << 4 | charToByte(hexChars[pos + 1]));
}
return d;
}
/**
* Convert char to byte
* @param c char
* @return byte
*/
private static byte charToByte(char c) {
return (byte) "0123456789ABCDEF".indexOf(c);
}
/**
* @param args
*/
public static void main(String[] args) {
String msg = new String(new byte[] { 0x4f, 0x4b ,0x4f,0x4b,0x4f,0x4b,0x4f,0x4b});
System.out.println("【加密前】:" + msg);
// 加密
byte[] secretArr = SecretUtils.encryptMode(msg.getBytes(),Algorithm3DES);
System.out.println("【加密后】:" + new String(withoutAutofill(secretArr)));
// 解密
byte[] myMsgArr = SecretUtils.decryptMode(secretArr,Algorithm3DES);
System.out.println("【解密后】:" + new String(myMsgArr));
}
}
相关推荐
主要介绍了使用java自带des加密算法实现文件加密和字符串加密的示例,需要的朋友可以参考下
在Java中,我们可以使用`javax.crypto`包中的`Cipher`类来实现3DES加密和解密。首先,我们需要创建一个`SecretKeySpec`对象,用于存储我们的密钥。密钥长度可以是128位(16字节),但3DES实际只使用其中的112位或168...
在C语言中实现3DES加密算法,可以确保在不同平台上的兼容性和一致性,尤其对于需要跨平台操作的应用场景,如将C语言代码移植到Android平台,通过JNI接口与Java代码交互,能够很好地解决加解密结果不一致的问题。...
Java 实现文件的 RSA 和 DES 加密 在现代密码技术中,根据密钥类型的不同,可以将其分为两类:对称加密算法(秘密钥匙加密)和非对称加密算法(公开密钥加密)。对称加密算法用来对敏感数据等信息进行加密,常用的...
java代码-使用java解决DES加密解密的源代码 ——学习参考资料:仅用于个人学习使用!
标题中的"Des.JAVA.rar_DES.java_DES加密_java DES 128bit_java des_加密解密"表明这是一个关于Java实现DES(Data Encryption Standard)加密算法的压缩包,其中包含用于加密和解密的源代码。DES是一种对称加密算法...
Java 3des加密算法ECB模式,亲测完美通过。目前网上的大部分算法都通不过或者加进Base64之类的,还要不下载其它jar包。而代码使用时直接下载运行,无须配置和下载额外的jar包 ,只需换上自己的密钥和待加密的数据...
压缩包中的文件可能包含了Java源代码和JavaScript源代码示例,以及可能的测试数据。这些文件可以直接运行,用于演示如何在Java和JavaScript之间进行DES加密解密。通过查看和理解这些代码,你可以更好地了解如何在...
### 利用DES加密算法保护Java源代码 #### 一、引言 随着信息技术的快速发展,数据的安全性问题越来越受到人们的重视。对于软件开发者来说,保护自己的Java源代码不被非法访问或篡改是非常重要的。Java作为一种跨...
在本项目中,“des加密解密(java和c语言互通)”指的是实现了一个能够在Java和C语言之间无缝进行DES加密和解密的解决方案。一周的开发工作旨在确保两个不同编程语言编写的程序可以相互读取和处理由DES算法加密或...
Java 中的 3DES 加密解密示例(封装 byte 数组和 16 进制字符串互转) 在 Java 中,3DES 加密是一种常用的加密算法,它可以将明文数据转换为密文数据,以保护数据的安全性。在本示例中,我们将展示如何使用 3DES ...
在Java中,可以使用`Cipher.getInstance("DESede/CBC/PKCS5Padding")`进行3DES加密。 4. **RSA( Rivest-Shamir-Adleman)** RSA是一种非对称加密算法,基于大整数因子分解的困难性。它有两个密钥:公钥用于加密,...
标题"DES加密算法(JAVA和C语言描述)结果一致"表明我们将探讨如何在两种不同的编程语言——Java和C中实现DES加密,确保得到相同的加密结果。在跨语言实现加密算法时,一致性至关重要,因为这确保了无论在哪种环境下...
标题中的“java和C#通用des3加解密”指的是在Java和C#这两种不同的编程语言中实现DES(Data Encryption Standard)的加强版——3DES(Triple DES)加解密算法。3DES是一种广泛使用的对称加密算法,通过三次应用DES的...
然后,在代码中引入库并实现3DES加密: ```javascript var CryptoJS = require("crypto-js"); function encrypt3DES(plaintext, key) { var key = CryptoJS.enc.Utf8.parse(key); var iv = CryptoJS.enc.Utf8....
### DES加密算法JAVA代码知识点详解 #### 一、概述 数据加密标准(Data Encryption Standard,简称DES)是一种广泛使用的对称密钥加密技术。在Java中实现DES加密解密功能通常涉及以下几个关键类:`javax.crypto....
java代码-使用java解决3DES加密解密的源代码 ——学习参考资料:仅用于个人学习使用!
在Java和JavaScript中实现3DES加密和解密,主要涉及以下几个关键知识点: 1. **密钥生成**:3DES需要一个168位的密钥,但通常我们提供的是一个128位或更短的密钥。Java中的`javax.crypto.SecretKeyFactory`和`javax...
用java代码实现DES的加密功能,简单的java类,含有加密和解密
在Java中实现DES和3DES加密,首先需要导入`javax.crypto`包下的相关类,如`Cipher`、`KeyGenerator`、`SecretKey`等。以下是一个简单的示例代码: ```java import javax.crypto.Cipher; import javax.crypto....