• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

浅析Java 常用的 4 种加密方式(MD5+Base64+SHA+BCrypt)

java 搞代码 4年前 (2022-01-05) 28次浏览 已收录 0个评论

这篇文章主要介绍了Java 常用的 4 种加密方式(MD5+Base64+SHA+BCrypt),本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下

一、工具类

 md5加密工具类 

 public class MD5Utils { private static final String hexDigIts[] = {"0","1","2","3","4","5","6","7","8","9","a","b","c","d","e","f"}; /** * MD5加密 * @param origin 字符 * @param charsetname 编码 * @return */ public static String MD5Encode(String origin, String charsetname){ String resultString = null; try{ resultString = new String(origin); MessageDigest md = MessageDigest.getInstance("MD5"); if(null == charsetname || "".equals(charsetname)){ resultString = byteArrayToHexString(md.digest(resultString.getBytes())); }else{ resultString = byteArrayToHexString(md.digest(resultString.getBytes(charsetname))); } }catch (Exception e){ } return resultString; } public static String byteArrayToHexString(byte b[]){ StringBuffer resultSb = new StringBuffer(); for(int i = 0; i <b.length; i++){ resultSb.append(byteToHexString(b[i])); } return resultSb.toString(); } public static String byteToHexString(byte b){ int n = b; if(n <0){ n += 256; } int d1 = n / 16; int d2 = n % 16; return hexDigIts[d1] + hexDigIts[d2]; } }

base64加密工具类

 public class Base64Util { // 字符串编码 private static final String UTF_8 = "UTF-8"; /** * 加密字符串 * @param inputData * @return */ public static String decodeData(String inputData) { try { if (null == inputData) { return null; } return new String(Base64.decodeBase64(inputData.getBytes(UTF_8)), UTF_8); } catch (UnsupportedEncodingException e) { } return null; } /** * 解密加密后的字符串 * @param inputData * @return */ public static String encodeData(String inputData) { try { if (null == inputData) { return null; } return new String(Base64.encodeBase64(inputData.getBytes(UTF_8)), UTF_8); } catch (UnsupportedEncodingException e) { } return null; } public static void main(String[] args) { System.out.println(Base64Util.encodeData("我是中文")); String enStr = Base64Util.encodeData("我是中文"); System.out.println(Base64Util.decodeData(enStr)); } }

 Bcrypt工具类

 public class BcryptCipher { // generate salt seed private static final int SALT_SEED = 12; // the head fo salt private static final String SALT_STARTSWITH = "$2a$12"; public static final String SALT_KEY = "salt"; public static final String CIPHER_KEY = "cipher"; /** * Bcrypt encryption algorithm method * @param encryptSource * need to encrypt the string * @return Map , two values in Map , salt and cipher */ public static Map Bcrypt(final String encryptSource) { String salt = BCrypt.gensalt(SALT_SEED); Map bcryptResult = Bcrypt(salt, encryptSource); return bcryptResult; } /** * * @param salt encrypt salt, Must conform to the rules * @param encryptSource * @return */ public static Map Bcrypt(final String salt, final String encryptSource) { if (StringUtils.isBlank(encryptSource)) { throw new RuntimeException("Bcrypt encrypt input params can not be empty"); } if (StringUtils.isBlank(salt) || salt.length() != 29) { throw new RuntimeException("Salt can't be empty and length must be to 29"); } if (!salt.startsWith(SALT_STARTSWITH)) { throw new RuntimeException("Invalid salt version, salt version is $2a$12"); } String cipher = BCrypt.hashpw(encryptSource, salt); Map bcryptResult = new HashMap(); bcryptResult.put(SALT_KEY, salt); bcryptResult.put(CIPHER_KEY, cipher); return bcryptResult; } }

二、加密测试

MD5加密测试 

 /** * MD5加密 */ public class MD5Test { public static void main(String[] args) { String string = "你好 世界"; String byteArrayToHexString = MD5Utils.byteArrayToHexString(string.getBytes()); System.out.println(byteArrayToHexString);//e68891e698afe4b880e58fa5e8af9d } }

base64加密测试 

 /** * base64加密 */ public class Bast64Tester { public static void main(String[] args) { String string = "你好 世界"; String encodeData = Base64Util.encodeData(string); //加密 String decodeData = Base64Util.decodeData(encodeData); //解密 System.out.println(encodeData);//5oiR5piv5LiA5Liq5a2X56ym5Liy System.out.println(decodeData);//你好 世界 } }

SHA加密测试 

 /** * SHA加密 */ public class ShaTest { public static void main(String[] args) { String string = "你好 世界"; String sha256Crypt = Sha2Crypt.sha256Crypt(string.getBytes()); System.out.println(sha256Crypt);//$5$AFoQTeyt$TiqmobvcQXjXaAQMYosAAO4KI8LfigZMGHzq.Dlp4NC } }

BCrypt加密测试

 /** * BCrypt加密 */ public class BCryptTest { public static void main(String[] args) { String string = "你好世界"; Map bcrypt = BcryptCipher.Bcrypt(string); System.out.println(bcrypt.keySet()); //[cipher, salt] System.out.printl<p style="color:transparent">来源gao!%daima.com搞$代*!码$网</p>n(bcrypt.get("cipher")); //$2a$12$ylb92Z84gqlrSfzIztlCV.dK0xNbw.pOv3UwXXA76llOsNRTJsE/. System.out.println(bcrypt.get("salt")); //$2a$12$ylb92Z84gqlrSfzIztlCV. Map bcrypt2 = BcryptCipher.Bcrypt(bcrypt.get("salt"),string); System.out.println(bcrypt2.get("SALT_KEY")); //null System.out.println(bcrypt2.get("CIPHER_KEY")); //null } }

总结

如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

以上就是浅析Java 常用的 4 种加密方式(MD5+Base64+SHA+BCrypt)的详细内容,更多请关注gaodaima搞代码网其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:浅析Java 常用的 4 种加密方式(MD5+Base64+SHA+BCrypt)

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址