首頁> Java> java教程> 主體

如何使用java 3DES加解密

php中世界最好的语言
發布: 2018-06-04 13:36:43
原創
2563 人瀏覽過

這次帶給大家如何使用java 3DES加解密,使用java 3DES加解密的注意事項有哪些,以下就是實戰案例,一起來看一下。

Java写的加密解密算法及调用范例 1、.JAVA算法范例 package Common.JUtility; import javax.crypto.*; import javax.crypto.spec.SecretKeySpec; import com.sun.org.apache.xerces.internal.impl.dv.util.Base64; public class EncryptUtils { ///  /// 3des解码 ///  /// 待解密字符串 /// 原始密钥字符串 ///  public static String Decrypt3DES(String value, String key) throws Exception { byte[] b = decryptMode(GetKeyBytes(key), Base64.decode(value)); return new String(b); } ///  /// 3des加密 ///  /// 待加密字符串 /// 原始密钥字符串 ///  public static String Encrypt3DES(String value, String key) throws Exception { String str = byte2Base64(encryptMode(GetKeyBytes(key), value.getBytes())); return str; } //计算24位长的密码byte值,首先对原始密钥做MD5算hash值,再用前8位数据对应补全后8位 public static byte[] GetKeyBytes(String strKey) throws Exception { if (null == strKey || strKey.length() < 1) throw new Exception("key is null or empty!"); java.security.MessageDigest alg = java.security.MessageDigest.getInstance("MD5"); alg.update(strKey.getBytes()); byte[] bkey = alg.digest(); System.out.println("md5key.length=" + bkey.length); System.out.println("md5key=" + byte2hex(bkey)); int start = bkey.length; byte[] bkey24 = new byte[24]; for (int i = 0; i < start; i++) { bkey24[i] = bkey[i]; } for (int i = start; i < 24; i++) {//为了与.net16位key兼容 bkey24[i] = bkey[i - start]; } System.out.println("byte24key.length=" + bkey24.length); System.out.println("byte24key=" + byte2hex(bkey24)); return bkey24; } private static final String Algorithm = "DESede"; //定义 加密算法,可用 DES,DESede,Blowfish //keybyte为加密密钥,长度为24字节 //src为被加密的数据缓冲区(源) public static byte[] encryptMode(byte[] keybyte, byte[] src) { try { //生成密钥 SecretKey deskey = new SecretKeySpec(keybyte, Algorithm); //加密 Cipher c1 = Cipher.getInstance(Algorithm); 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; } //keybyte为加密密钥,长度为24字节 //src为加密后的缓冲区 public static byte[] decryptMode(byte[] keybyte, byte[] src) { try { //生成密钥 SecretKey deskey = new SecretKeySpec(keybyte, 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; } //转换成base64编码 public static String byte2Base64(byte[] b) { return Base64.encode(b); } //转换成十六进制字符串 public static String byte2hex(byte[] b) { String hs = ""; String stmp = ""; for (int n = 0; n < b.length; n++) { stmp = (java.lang.Integer.toHexString(b[n] & 0XFF)); if (stmp.length() == 1) hs = hs + "0" + stmp; else hs = hs + stmp; if (n < b.length - 1) hs = hs + ":"; } return hs.toUpperCase(); } } 2、JAVA 算法调用范例 package test.com; import com.sun.org.apache.xerces.internal.impl.dv.util.Base64; import Common.JUtility.EncryptUtils;//用原始密钥经MD5转换和补位后的新密钥来做3DES加密解密 public class Test3DES { public static void main(String[] args) { String key = "abcd1234"; String password = "password"; System.out.println("key=" + key + ",password=" + password); System.out.println(); System.out.println("----------示例开始:使用java写的算法加密解密-----------"); try { String encrypt = ""; String decrypt = ""; byte[] bkey = EncryptUtils.GetKeyBytes(key); encrypt = EncryptUtils.byte2Base64(EncryptUtils.encryptMode(bkey, password.getBytes())); System.out.println("用预转换密钥算加密结果=" + encrypt); System.out.println("加密后base64表示=" + EncryptUtils.byte2hex(Base64.decode(encrypt))); System.out.println("调用原始密钥算加密结果=" + EncryptUtils.Encrypt3DES(password, key)); try { decrypt = new String(EncryptUtils.decryptMode(bkey, Base64.decode(encrypt))); System.out.println("用预转换密钥算解密结果=" + decrypt); System.out.println("调用原始密钥算解密结果=" + EncryptUtils.Decrypt3DES(encrypt, key)); } catch (Exception ex) { System.out.println("Exception:" + ex.getMessage()); } } catch (Exception ex) { System.out.println("Exception:" + ex.getMessage()); } System.out.println("----------示例结束:使用java写的算法加密解密-----------"); } } 3、(7)的运算结果 key=abcd1234,password=password ----------示例开始:使用java写的算法加密解密----------- md5key.length=16 md5key=E1:9D:5C:D5:AF:03:78:DA:05:F6:3F:89:1C:74:67:AF byte24key.length=24 byte24key=E1:9D:5C:D5:AF:03:78:DA:05:F6:3F:89:1C:74:67:AF:E1:9D:5C:D5:AF:03:78:DA 用预转换密钥算加密结果=ftwPzxFH4WpzT4Orq8uSLQ== 加密后base64表示=7E:DC:0F:CF:11:47:E1:6A:73:4F:83:AB:AB:CB:92:2D md5key.length=16 md5key=E1:9D:5C:D5:AF:03:78:DA:05:F6:3F:89:1C:74:67:AF byte24key.length=24 byte24key=E1:9D:5C:D5:AF:03:78:DA:05:F6:3F:89:1C:74:67:AF:E1:9D:5C:D5:AF:03:78:DA 调用原始密钥算加密结果=ftwPzxFH4WpzT4Orq8uSLQ== 用预转换密钥算解密结果=password md5key.length=16 md5key=E1:9D:5C:D5:AF:03:78:DA:05:F6:3F:89:1C:74:67:AF byte24key.length=24 byte24key=E1:9D:5C:D5:AF:03:78:DA:05:F6:3F:89:1C:74:67:AF:E1:9D:5C:D5:AF:03:78:DA 调用原始密钥算解密结果=password ----------示例结束:使用java写的算法加密解密-----------
登入後複製

相信看了本文案例你已經掌握了方法,更多精彩請關注php中文網其它相關文章!

推薦閱讀:

行動端WEB開發中click,touch,tap事件使用詳解

REM相對單位使用案例分享

以上是如何使用java 3DES加解密的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!