时间:2021-05-19
java加密算法--MD5加密和哈希散列带秘钥加密算法源码
最近学习加密算法的知识,利用MD5加密,百度一下网上资料很多,不是很详细,这里就整理下如何实现用MD5加密和 哈希散列带秘钥加密算法,大家可以看下。
实现代码:
package com.ompa.common.utils;import java.security.MessageDigest;import java.security.NoSuchAlgorithmException;import javax.crypto.Mac;import javax.crypto.SecretKey;import javax.crypto.spec.SecretKeySpec;/*** 采用MD5加密 * * @author zhangcd* @date 2016-4-29*/public class EncryptUtil { private static final String MAC_NAME = "HmacSHA1"; private static final String ENCODING = "UTF-8"; private static final String key = "iloveyou";/*** * MD5加码 生成32位md5码 */ public static String string2MD5(String inStr){ MessageDigest md5 = null; try{ md5 = MessageDigest.getInstance("MD5"); }catch (Exception e){ System.out.println(e.toString()); e.printStackTrace(); return ""; } char[] charArray = inStr.toCharArray(); byte[] byteArray = new byte[charArray.length]; for (int i = 0; i < charArray.length; i++) byteArray[i] = (byte) charArray[i]; byte[] md5Bytes = md5.digest(byteArray); StringBuffer hexValue = new StringBuffer(); for (int i = 0; i < md5Bytes.length; i++){ int val = ((int) md5Bytes[i]) & 0xff; if (val < 16) hexValue.append("0"); hexValue.append(Integer.toHexString(val)); } return hexValue.toString(); } /*** * MD5加密 生成32位md5码 */ public static String stringMD5(String inStr){ return string2MD5(string2MD5(inStr)); }/** * 加密解密算法*/ public static String convertMD5(String inStr){ char[] a = inStr.toCharArray(); for (int i = 0; i < a.length; i++){ a[i] = (char) (a[i] ^ 't'); } String s = new String(a); return s; } /** * HMAC-SHA1 * @param encryptText * @param encryptKey * @return * @throws Exception */ public static String HmacSHA1Encrypt(String encryptText, String encryptKey) throws Exception { byte[] data=encryptKey.getBytes(ENCODING); SecretKey secretKey = new SecretKeySpec(data, MAC_NAME); Mac mac = Mac.getInstance(MAC_NAME); mac.init(secretKey); byte[] text = encryptText.getBytes(ENCODING); byte[] str = mac.doFinal(text);// Create Hex StringStringBuffer hexString = new StringBuffer();// 字节数组转换为 十六进制 数for (int i = 0; i < str.length; i++) {String shaHex = Integer.toHexString(str[i] & 0xFF);if (shaHex.length() < 2) {hexString.append(0);}hexString.append(shaHex);}return hexString.toString();} public static String convertSHA1(String instr){try {return HmacSHA1Encrypt(instr,key);} catch (Exception e) {// TODO Auto-generated catch blocke.printStackTrace();return "";}}// 测试主函数 public static void main(String args[]) throws Exception { //哈希散列带秘钥加密String tt = convertSHA1("123456");System.out.println(tt);//MD5加密String s = new String("123456"); System.out.println("原始:" + s); System.out.println("MD5后:" + string2MD5(s)); System.out.println("MD5加密后:" + stringMD5(s));} }感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
常见的加密算法基本分为这几类,1:线性散列算法、2:对称性加密算法、3、非对称性加密算法(记记记)线性散列算法(签名算法):MD5,SHA1,HMAC比如MD5
Md5()加密算法方式:单向加密语法:md5(string$str[,bool$raw_output=false])$str:原始字符串$raw_output:
1、md5加密,该加密算法是单向加密,即加密的数据不能再通过解密还原。相关类包含在java.security.MessageDigest包中。2、3-DES加密
RSA加密算法我们来回顾一下RSA的加密算法。我们从公钥加密算法和签名算法的定义出发,用比较规范的语言来描述这一算法。RSA公钥加密体制包含如下3个算法:Key
在实际编程开发中,我们会使用到各类的加密算法来对数据和信息进行加密。比如密码中比较常见的MD5加密,以及AES加密等等。对于密码认证来说,MD5加密是比较适合的