Java加密之SHA加盐

import java.math.BigInteger;
import java.security.MessageDigest;
import java.security.SecureRandom;
import java.util.HashMap;
import java.util.Map;

public class SHA {
	public static final String KEY_SHA = "SHA";   
	public static final String ra="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789";

	/**
	 * 字符串sha加密
	 * @param s 要加密的字符串
	 * @return 加密后的字符串
	 */
	public static String sha(String s)
	{
	    BigInteger sha =null;
	    byte[] bys = s.getBytes();   
	    try {
	         MessageDigest messageDigest = MessageDigest.getInstance(KEY_SHA);  
	         messageDigest.update(bys);
	         sha = new BigInteger(messageDigest.digest());
	    } catch (Exception e) {
	    	e.printStackTrace();
	    }
	    return sha.toString(32);
	}
	
	/**
	 * 字符串+随机盐 sha加密
	 * @param s 要加密的字符串
	 * @return 盐和加密后的字符串
	 */	
	public static Map<String,String> getResult(String s){
		Map<String,String> map=new HashMap<String,String>();
		String salt=getSalt();
		map.put("salt", salt);//盐
		map.put("password", sha(s+salt));//加密后的密码
 	    return map;
	}
	
	/**
	 * 生成随机盐
	 * @return 随机生成的盐
	 */
	private static String getSalt() {
		SecureRandom random=new SecureRandom();
		int length=random.nextInt(5)+8;//盐的长度,这里是8-12可自行调整
        char[] text = new char[length];
        for (int i = 0; i < length; i++) {
            text[i] = ra.charAt(random.nextInt(ra.length()));
        }
        return new String(text);
    }
	
	/**
	 * 测试方法
	 * @param args
	 */
	public static void main(String[] args) {
		System.out.println(getResult("12345678"));
	}

 

Java中的MessageDigest类是一个用于创建消息摘要的工具类,它可以用于生成数据的哈希值。加密加盐是数据安全中的两个重要概念。加密是指使用某种算法将可读的数据(明文)转换成不可读的数据(密文),以防止数据泄露。而加盐则是指在加密前给数据添加随机数据(即“盐”),以增加密码的复杂度,使得相同的密码通过加盐后会得到不同的哈希值,从而提高安全性。 在Java中使用MessageDigest进行加密加盐的步骤通常包括以下几个: 1. 导入`java.security.MessageDigest`类。 2. 初始化MessageDigest实例,指定所需的加密算法(如SHA-256)。 3. 对数据进行分块处理,并使用MessageDigest的`update()`方法更新数据。 4. 调用`digest()`方法来计算数据的哈希值。 5. 如果要加盐,可以在更新数据之前将盐值与原始数据结合。 下面是一个简单的例子: ```java import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; import java.util.Base64; public class DigestWithSalt { public static String encrypt(String str, String salt, String algorithm) { try { // 创建MessageDigest实例 MessageDigest md = MessageDigest.getInstance(algorithm); // 加盐 byte[] saltBytes = salt.getBytes(); // 更新MessageDigest实例以加入盐 md.update(saltBytes); // 加密数据 byte[] bytes = md.digest(str.getBytes()); // 返回Base64编码后的字符串 return Base64.getEncoder().encodeToString(bytes); } catch (NoSuchAlgorithmException e) { e.printStackTrace(); return null; } } public static void main(String[] args) { String text = "password"; String salt = "somesalt"; String algorithm = "SHA-256"; String encryptedText = encrypt(text, salt, algorithm); System.out.println("加密后的文本:" + encryptedText); } } ``` 在上述代码中,我们定义了一个`encrypt`方法,该方法接受原始字符串、盐和加密算法作为参数,返回加密后的字符串。这里使用了Base64编码来将二进制数据转换成字符串形式,以便于查看和传输。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值