工具类 密码加密


public class PasswordDigester {


private static Logger logger = Logger.getLogger(PasswordDigester.class);


private static final String ALGORITHM_MD5 = "MD5";


/**
* Encrypt the password with MD5

* @param pass
*            the password to encryption
* @return encryption string
*/
public static String getPassMD5(String pass) {
String keys = null;
try {
MessageDigest md = MessageDigest.getInstance(ALGORITHM_MD5);
if (pass == null) {
pass = "";
}
byte[] bPass = pass.getBytes("UTF-8");
md.update(bPass);
// keys = new String(md.digest(), "GBK");
keys = bytesToHexString(md.digest());
} catch (NoSuchAlgorithmException aex) {
logger.error("there is no " + ALGORITHM_MD5 + " Algorithm!");
} catch (java.io.UnsupportedEncodingException uex) {
logger.error("can not encode the password - " + uex.getMessage());
}
return keys;
}


/**
* 将beye[]转换为十六进制字符串

* @param bArray
* @return
*/
public static final String bytesToHexString(byte[] bArray) {
StringBuffer sb = new StringBuffer(bArray.length);
String sTemp;
for (int i = 0; i < bArray.length; i++) {
sTemp = Integer.toHexString(0xFF & bArray[i]);
if (sTemp.length() < 2) {
sb.append(0);
}
sb.append(sTemp.toUpperCase());
}
return sb.toString();
}
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
SM4是一种对称密钥分组密码算法,全称为“Stream Cipher SM4”,它在中国的商用密码算法标准中得到了应用。在Java中,如果你想要使用SM4进行加密,可以借助开源库如BCryptor、Java Cryptography Extension (JCE)等提供的支持。 例如,使用Bouncy Castle库来实现SM4加密,你可以创建一个简单的工具类步骤如下: ```java import org.bouncycastle.jce.provider.BouncyCastleProvider; import javax.crypto.Cipher; import javax.crypto.spec.IvParameterSpec; import javax.crypto.spec.SecretKeySpec; public class Sm4Encryptor { static { // 初始化BouncyCastle provider Security.addProvider(new BouncyCastleProvider()); } private static final String ALGORITHM = "AES/SM4/CBC"; private static final String IV = "0123456789abcdef"; // 使用固定的初始化向量 public static byte[] encrypt(String data, String key) throws Exception { SecretKeySpec secretKey = new SecretKeySpec(key.getBytes(), ALGORITHM); IvParameterSpec iv = new IvParameterSpec(IV.getBytes()); Cipher cipher = Cipher.getInstance(ALGORITHM, BouncyCastleProvider.PROVIDER_NAME); cipher.init(Cipher.ENCRYPT_MODE, secretKey, iv); return cipher.doFinal(data.getBytes()); } public static String decrypt(byte[] encryptedData, String key) throws Exception { // 解密过程类似,只是cipher.init需要传CIPHER_DECRYPT_MODE // 具体实现略去 } } ``` 这个工具类提供了一个`encrypt`方法用于加密数据,接收输入字符串和密钥作为参数。在实际使用时,你需要妥善处理密钥的安全存储,并确保在解密时使用相同的密钥。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

houzhanwublog

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值