目前客户端使用的。
import java.security.Key;
import java.security.MessageDigest;
import java.security.spec.AlgorithmParameterSpec;
import javax.crypto.Cipher;
import javax.crypto.SecretKeyFactory;
import javax.crypto.spec.DESKeySpec;
import javax.crypto.spec.IvParameterSpec;
public class EncryptUtil {
public final static String DES = "DES";
public final static String MD5 = "MD5";
static AlgorithmParameterSpec iv = null;// 加密算法的参数接口,IvParameterSpec是它的一个实现
private static Key key = null;
public static String encode(String sKey) throws Exception {
String sKeyFormat = "ICITIC_PWD";
byte[] inputByteArray = sKey.getBytes();
byte[] desKey = getMD5ofStr(sKeyFormat).substring(0, 8).getBytes();
byte[] desIV = getMD5ofStr(sKeyFormat).substring(0, 8).getBytes();
CryptoTools(desKey, desIV);
Cipher enCipher = Cipher.getInstance("DES/CBC/PKCS5Padding");// 得到加密对象Cipher
enCipher.init(Cipher.ENCRYPT_MODE, key, iv);// 设置工作模式为加密模式,给出密钥和向量
byte[] pasByte = enCipher.doFinal(inputByteArray);
StringBuffer sb = new StringBuffer();
sb.append(bytes2HexString(pasByte));
return sb.toString();
}
// 设置加密工具
private static void CryptoTools(byte[] DESkey, byte[] DESIV)
throws Exception {
DESKeySpec keySpec = new DESKeySpec(DESkey);// 设置密钥参数
iv = new IvParameterSpec(DESIV);// 设置向量
SecretKeyFactory keyFactory = SecretKeyFactory.getInstance(DES);// 获得密钥工厂
key = keyFactory.generateSecret(keySpec);// 得到密钥对象
}
// MD5加密
private static String getMD5ofStr(String sKeyFormat) {
try {
byte[] str = sKeyFormat.getBytes();
MessageDigest md = MessageDigest.getInstance(MD5);
md.update(str);
byte[] b = md.digest();
return bytes2HexString(b);
} catch (Exception e) {
e.printStackTrace();
}
return null;
}
public static void main(String[] args) {
try {
System.out.println(encode("888888"));
} catch (Exception e) {
e.printStackTrace();
}
}
public static String bytes2HexString(byte[] bytes) {
String hs = null;
if (bytes != null) {
final int size = bytes.length;
if (size > 0) {
StringBuilder sb = new StringBuilder();
for (int i = 0; i < size; i++) {
String tmp = (java.lang.Integer
.toHexString(bytes[i] & 0XFF));
if (tmp.length() == 1) {
sb.append("0" + tmp);
} else {
sb.append(tmp);
}
}
hs = sb.toString().toUpperCase();
}
}
return hs;
}
}
结果:
BB8DF9AB68109156
分享到:
相关推荐
基于STM32的软件加解密算法,包括DES,3DES的ECB,CBC模式。但是验证时CBC模式的初始向量为0时,数据的...已上传新的验证代码:DES_3DES加解密算法(更新),如有需要请自行在本人上传资源中查找,如有测试不过的请私信。
3DES加密解密的全工具类,快速帮助新人进行3Des加密解密
对数据进行单DES或者3DES加密或者解密,如果密码长度为8字节则为DES加密或者解密
对数据进行3DES加密或者解密,如果密码长度为8字节则为DES加密或者解密
DES加密解密(c++实现)
des加解密说明及代码应用,des加解密服务端java的实现以及对js端应用的实现
des加密解密工具
DES加密解密工具DES加密解密工具DES加密解密工具DES加密解密工具DES加密解密工具DES加密解密工具DES加密解密工具DES加密解密工具DES加密解密工具
DES加密解密算法的C语言实现,只要调用函数,即可实现数据的加密解密,我已经在DSP上实现。
一个调用动态链接库的des加密解密例子。
DES加密解密程序的C源码.喜欢就下~~~
例子代码,用c++实现了先用3DES进行内容的加密再用Base64加密输出,和先用base64解密再用3DES解密输出两个例子,完成了网址常用的加解密输出.代码是用vs2013实现的。
des加密解密java实现des加密解密java实现des加密解密java实现des加密解密java实现des加密解密java实现des加密解密java实现
DES加密解密程序,VC源码值得学习借鉴
支持3DES加密 解密 类中利用函数重载的方式 实现两种加密方式 加密后为16进制字符串 使用方法: 实例化一个对象 然后就可以随便用了。 如 DES加密 解密 CString sd,sd2; yxyDES2 des; sd=des.DESr("wan123456",...
3DES加密解密java版+js版
3次Des加解密 3次Des加解密
visual c++实现3des加解密 加密解密.zip
C#实现的DES加解密的类文件源代码、压缩等功能。
DES加密解密实验报告,内容详细,尤其是实验原理部分写的很多,另外重点研究了DES的弱密钥问题,有运行结果截图,没有源代码。