* @param arrB 需要转换的byte数组
* @return 转换后的字符串
* @throws Exception 本方法不处理任何异常,所有异常全部抛出
*/
public static String byteArr2HexStr(byte[] arrB) throws Exception {
int iLen = arrB.length
// 每个byte用两个字符才能表示,所以字符串的长度是数组长度的两倍
StringBuffer sb = new StringBuffer(iLen * 2)
for (int i = 0i <iLeni++) {
int intTmp = arrB[i]
// 把负数转换为正数
while (intTmp <0) {
intTmp = intTmp + 256
}
// 小于0F的数需要在前面补0
if (intTmp <16) {
sb.append("0")
}
sb.append(Integer.toString(intTmp, 16))
}
return sb.toString()
}
/*
* @param strIn 需要转换的字符串
* @return 转换后的byte数组
* @throws Exception 本方法不处理任何异常,所有异常全部抛出
*/
public static byte[] hexStr2ByteArr(String strIn) throws Exception {
byte[] arrB = strIn.getBytes()
int iLen = arrB.length
// 两个字符表示一个字节,所以字节数组长度是字符串长度除以2
byte[] arrOut = new byte[iLen / 2]
for (int i = 0i <iLeni = i + 2) {
String strTmp = new String(arrB, i, 2)
arrOut[i / 2] = (byte) Integer.parseInt(strTmp, 16)
}
return arrOut
}
/**
* 加密字节数组
*
* @param arrB
*需加密的字节数组
* @return 加密后的字节数组
* @throws Exception
*/
@SuppressWarnings("restriction")
private static byte[] encrypt(byte[] arrB,String keyParameter) throws Exception {
Security.addProvider(new com.sun.crypto.provider.SunJCE())
Key key = getKey(keyParameter.getBytes())
Cipher encryptCipher = Cipher.getInstance("DES")
encryptCipher.init(Cipher.ENCRYPT_MODE, key)
return encryptCipher.doFinal(arrB)
}
/**
* 加密字符串
*
* @param strIn
*需加密的字符串
* @return 加密后的字符串
* @throws Exception
*/
public static String encrypt(String strIn,String keyParameter) throws Exception {
return HexStrByteArrUtils.byteArr2HexStr(encrypt(strIn.getBytes(PiccConfig.PICC_INPUT_CHARSET),keyParameter))
}
/**
* 解密字节数组
*
* @param arrB
*需解密的字节数组
* @return 解密后的字节数组
* @throws Exception
*/
@SuppressWarnings("restriction")
private static byte[] decrypt(byte[] arrB,String keyParameter) throws Exception {
Security.addProvider(new com.sun.crypto.provider.SunJCE())
Key key = getKey(keyParameter.getBytes())
Cipher decryptCipher = Cipher.getInstance("DES")
decryptCipher.init(Cipher.DECRYPT_MODE, key)
return decryptCipher.doFinal(arrB)
}
/**
* 解密字符串
*
* @param strIn
*需解密的字符串
* @return 解密后的字符串
* @throws Exception
*/
public static String decrypt(String strIn,String keyParameter) throws Exception {
return new String(decrypt(HexStrByteArrUtils.hexStr2ByteArr(strIn),keyParameter),PiccConfig.PICC_INPUT_CHARSET)
}
加密解密并非java才有的,所有编程语言都有加密和解密。
目前的加密解密主要可分为以下2大类:
对称秘钥加密:如DES算法,3DES算法,TDEA算法,Blowfish算法,RC5算法,IDEA算法等。其主要特点是加密方和解密方都有同一个密码,加密方和解密方可以使用秘钥任意加密解密。
非对称密码加密:这种加密方式加密方仅有加密秘钥,对加密后的密文无法反向解密,解密方仅有解密秘钥,无法对明文进行加密。
另外还有一些摘要算法,比如MD5和HASH此类算法不可逆,但经常用来作为确认字段或者对一些重要匹配信息签名防止明文内容被修改。