package com.snail.util; import java.io.UnsupportedEncodingException; import java.security.MessageDigest; import javax.crypto.Cipher; import javax.crypto.spec.SecretKeySpec; import com.d1xn.common.base.SystemConfig; import com.d1xn.common.log.Log; /** * 一般加密解密工具<br> * DESede/DES/BlowFish<br> * DES的密钥(key)长度是为8个字节,加密解密的速度是最快的<br> * DESede的密钥(key)长度是24个字节<br> * BlowFish的密钥(key)是可变的 加密最快,强度最高,密钥长度范围(1<=key<=16)<br> * * @author penghuaiyi * @version 1.0 */ public class SecretCodeUtil { public final static String DES = "DES"; public final static String DESEDE = "DESede"; public final static String BLOWFISH = "BlowFish"; public final static String MD5 = "MD5"; /** * md5加密 * * @param plainText * @return 加密后的大写字符串 */ public static String getMD5ofStr(String plainText) { try { return getMD5ofStr(string2Bytes(plainText)); } catch (Exception e) { e.printStackTrace(); } return null; } /** * md5加密 * * @param str * @return 加密后的大写字符串 */ public static String getMD5ofStr(byte str[]) { try { MessageDigest md = MessageDigest.getInstance(MD5); md.update(str); byte b[] = md.digest(); return bytes2HexString(b); } catch (Exception e) { e.printStackTrace(); } return null; } /** * 字符串加密 * * @param data * 字符串数据 * @param key * 密钥 * @param name * 算法名称 * @throws Exception */ public static String encrypt(String data, String key, String name) { try { return bytes2HexString(encrypt(data.getBytes(), string2Bytes(key), name)); } catch (Exception e) { e.printStackTrace(); } return null; } /** * 字符串加密 * * @param data * 字符串数据 * @param key * 密钥 * @param name * 算法名称 * @throws Exception */ public static String encrypt(String data, byte[] key, String name) { try { return bytes2HexString(encrypt(data.getBytes(), key, name)); } catch (Exception e) { e.printStackTrace(); } return null; } /** * 字符串解密 * * @param data * 字符串加密数据 * @param key * 密钥 * @param name * 算法名称 * @return * @throws Exception */ public static String decrypt(String data, String key, String name) { try { return new String(decrypt(hex2byte(data.getBytes()), string2Bytes(key), name)); } catch (Exception e) { Log.error(SecretCodeUtil.class, e, "data:" + data); } return null; } /** * 字符串解密 * * @param data * 字符串加密数据 * @param key * 密钥 * @param name * 算法名称 * @return * @throws Exception */ public static String decrypt(String data, byte[] key, String name) { try { return new String(decrypt(hex2byte(data.getBytes()), key, name)); } catch (Exception e) { } return null; } /** * 对数据源进行加密 * * @param src * 数据源 * @param key * 密钥 * @param name * 算法的名称 * @return 返回加密后的数据 * @throws Exception */ private static byte[] encrypt(byte[] src, byte[] key, String name) throws Exception { SecretKeySpec securekey = new SecretKeySpec(key, name); // Cipher对象实际完成加密操作 Cipher cipher = Cipher.getInstance(name); // 用密匙初始化Cipher对象 cipher.init(Cipher.ENCRYPT_MODE, securekey); // 现在,获取数据并加密 // 正式执行加密操作 return cipher.doFinal(src); } /** * 对加密的数据源进行解密 * * @param src * 数据源 * @param key * 密钥 * @param name * 算法的名称 * @return 返回解密后的原始数据 * @throws Exception */ private static byte[] decrypt(byte[] src, byte[] key, String name) throws Exception { SecretKeySpec securekey = new SecretKeySpec(key, name); // Cipher对象实际完成解密操作 Cipher cipher = Cipher.getInstance(name); // 用密匙初始化Cipher对象 cipher.init(Cipher.DECRYPT_MODE, securekey); // 现在,获取数据并解密 // 正式执行解密操作 return cipher.doFinal(src); } /** * 二行制转字符串 * * @param b * @return */ private 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; } /** * 把字符串转化成 Unicode Bytes. * * @param s * String * @return byte[] */ private static byte[] string2Bytes(String s) { byte[] bytes = null; if (s != null) { try { bytes = s.getBytes(SystemConfig.DEFAULT_ENCODING); } catch (UnsupportedEncodingException e) { e.printStackTrace(); } } return bytes; } /** * 结字节进行转换 * * @param b * @return */ private static byte[] hex2byte(byte[] b) { if ((b.length % 2) != 0) { return null; } byte[] b2 = new byte[b.length / 2]; for (int n = 0; n < b.length; n += 2) { String item = new String(b, n, 2); b2[n / 2] = (byte) Integer.parseInt(item, 16); } return b2; } public static void main(String[] args){ //DES加密与解密 String key = "snail001"; String encrypt = SecretCodeUtil.encrypt("fuckyou2013", key, SecretCodeUtil.DES); //加密 System.out.println(encrypt); String decrypt = SecretCodeUtil.decrypt(encrypt, key, SecretCodeUtil.DES);//解密 System.out.println(decrypt); //MD5加密,不可逆的 String md5 = SecretCodeUtil.getMD5ofStr("fuckyou2013"); System.out.println(md5); } }
相关推荐
本文将详细介绍一个基于Java Base64的Android加密解密工具类,该工具类支持公钥加密和私钥解密,具有高度的解耦性,方便集成到项目中。 一、Base64加密解密基础 Base64是一种编码方式,它将任意二进制数据转换为可...
Java Base64加密解密方法工具类
java 3des加密、解密工具类 java的3DES加密/解密
AES加密解密工具类是开发人员在处理敏感信息时常用的实用工具,它可以简化加密和解密过程。本篇文章将深入探讨如何在Java中实现AES加密解密,并介绍相关的关键知识点。 首先,我们需要理解AES加密的基本原理。AES是...
java开发使用base64进行加密解密,开发人员只需调用其中方法即可完成加密解密操作!
RSA加密解密验签工具类
3DES加密解密的全工具类,快速帮助新人进行3Des加密解密
描述中的"SQLite数据库加密解密小工具"应该是一个.NET库或应用程序,它提供了对SQLite数据库加密和解密的功能。这个工具可能使用了某种加密算法(如AES)对数据库文件进行加解密,确保数据在存储和传输过程中的安全...
C# .net MD5加密解密工具及加密解密类。使用方便,可直接下载加密解密代码在项目中使用。
本文将详细介绍DES加密解密工具类及其使用,并解析在给定的文件列表中的`SecurityPropertyes.java`、`CryptoTools.java`和`SecurityUtil.java`这三个文件可能包含的内容。 首先,`CryptoTools.java`很可能是实现DES...
文件可能定义了一个名为UEncrypt的工具类,其中包含用于加密和解密的方法。这些方法可能接收字节数组或字符串作为输入,处理加密和解密的过程,并返回结果。 在实际应用中,注意以下几点: - 避免明文存储私钥,...
java中常用的工具类,用于MD5的加密,里面还有切割了MD5加密的长度,有DES加密与解密,并且配有main函数可测试,可以根据自己的实际情况使用main函数测试使用
微信服务好xml数据包加密解密工具类,来源于官方文档,下载完就能使用。 使用方式: 1.解压压缩包 2.将demo代码拷贝至编辑器中 3.打开Program类,通过maven自动将所有的依赖引入 4.根据自己的实际情况,修改toekn,...
在Java编程语言中,RSA(Rivest-Shamir-...总结来说,RSA加密解密工具类在Java中是一个重要的安全组件,用于保护数据的安全传输和存储。理解并正确使用RSA算法及其相关的Java API对于开发安全的网络应用程序至关重要。
这是一个Java的工具类,进行加密操作的时候调用该类的方法就可以,工具类里面写了一个main,拿啦直接用就行。
例如,可以使用`java.security.MessageDigest`类实现MD5和SHA哈希计算,`javax.crypto.Cipher`类处理DES和AES的加密解密,而`java.util.Base64`类则用于BASE64编码解码。 总的来说,这个"加密算法工具类"提供了一站...
java CRC32Util 加密解密工具类
这样的工具类在实际开发中非常实用,开发者可以方便地对字符串进行Base64编码解码,同时也可以进行MD5、DES和AES的加密解密操作,以满足不同层次的安全需求。 使用这些加密技术时,需要注意以下几点: - 对于敏感...
JavaMD5加密工具类 algorithm = MessageDigest.getInstance("MD5"); algorithm.reset(); algorithm.update(s.getBytes("UTF-8")); byte[] messageDigest = algorithm.digest(); return messageDigest;
DES加密解密java工具类 public static final String KEY_ALGORITHM = "DES"; public static final String CIPHER_ALGORITHM = "DES/ECB/PKCS5PADDING"; validKeySpecException, NoSuchPaddingException, ...