MD5加密技术(加盐)

2024-04-21 07:32
文章标签 md5 加盐 加密技术

本文主要是介绍MD5加密技术(加盐),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

import org.apache.commons.lang3.StringUtils;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import java.util.Random;public class MD5Util {public static void main(String[] args) {//字符串加密String str = "123456";String salt = getSalt();System.out.println(salt);System.out.println(getMD5CodeBySalt(str,salt));}//对字符串进行MD5编码public static String getMD5Code(String str){if(StringUtils.isBlank(str)){return null;}try {//创建具有指定算法名称的信息摘要MessageDigest md = MessageDigest.getInstance("MD5");//使用指定的字节数组对摘要进行最后的更新,然后完成摘要计算byte[] results = md.digest(str.getBytes());//将得到的字节数组编程字符串返回String resultString = byteArrayToHexString(results);return resultString.toUpperCase();} catch (NoSuchAlgorithmException e) {e.printStackTrace();}return null;}//对字符串进行MD5编码加盐操作public static String getMD5CodeBySalt(String str,String salt){if(StringUtils.isBlank(str)){return null;}return getMD5Code(getMD5Code(str)+salt);}//转换字节数组为十六进制字符串private static String byteArrayToHexString(byte[] results){StringBuffer resultNew = new StringBuffer();for(int i = 0;i < results.length;i++){resultNew.append(byteToHexString(results[i]));}return resultNew.toString();}//16进制下数字到字符的映射数组private static String[] HEXDIGITS = new String[]{"0","1","2","3","4","5","6","7","8","9","a","b","c","d","e","f"};//将字节转化成十六进制的字符串private static String byteToHexString(byte b){int byteNum = b;if(byteNum < 0){byteNum = byteNum + 256;}int d1 = byteNum / 16;int d2 = byteNum % 16;return HEXDIGITS[d1]+HEXDIGITS[d2];}//传入的字符串加密后和Md5字符串的比较,常用语登录时密码的核对private static boolean compareStringWithMD5Code(String str,String MD5Code){boolean isEquals = false;if(StringUtils.isBlank(str)){return isEquals;}if(MD5Code.equals(getMD5Code(str))){isEquals = true;}return isEquals;}//生成一个10位的随机saltpublic static String getSalt(){String salt = "";Random rand = new Random();for(int i=0;i<10;i++){int num = rand.nextInt(3);switch(num){case 0:char c1 = (char)(rand.nextInt(26)+'a');//生成随机小写字母salt += c1;break;case 1:char c2 = (char)(rand.nextInt(26)+'A');//生成随机大写字母salt += c2;break;case 2:salt += rand.nextInt(10);//生成随机数字}}return salt;}}

这篇关于MD5加密技术(加盐)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/922509

相关文章

C# Hash算法之MD5、SHA

MD5我们用的还是比较多的,一般用来加密存储密码。但是现在很多人觉MD5可能不太安全了,所以都用上了SHA256等来做加密(虽然我觉得都差不多,MD5还是能玩)。 还是跟上一篇说的一样,当一个算法的复杂度提高的同时肯定会带来效率的降低,所以SHA和MD5比较起来的话,SHA更安全,MD5更高效。 由于HASH算法的不可逆性,所以我认为MD5和SHA主要还是应用在字符串的"加密"上。 由于

Android的登陆MD5加密

1:导入代码 public class MD5Util {private static final String TAG = "MD5Util";/**** MD5加码 生成32位md5码*/public static String string2MD5(String inStr) {Log.e(TAG, "string2MD5: -------------------------");Mess

js中怎样对“abc”进行MD5、sha256哈希计算?

在 JavaScript 中,可以使用 CryptoJS 库来进行 MD5 哈希计算。首先,你需要在 HTML 文件中导入 CryptoJS 库,例如: <script src="https://cdnjs.cloudflare.com/ajax/libs/crypto-js/3.1.9-1/crypto-js.min.js"></script> 然后,在 JavaScript 文件中,可

C#根据文件绝对路径获得文件MD5值

/// <summary>/// 获取文件MD5值/// </summary>/// <param name="filePath">文件绝对路径</param>/// <returns>MD5值</returns>public static string GetMD5HashFromFile(string filePath){try{FileStream file = new FileStream

密码 加盐处理 是什么

问题 一般对密码都不会是明文存储,而是对密码进行MD5处理,增强反向解密难度。 但这样还是能可以找出破绽,因为MD5加密相同的数据,得到的密文是一样的。 如果用户可以查看数据库,那么他可以观察到自己的密码和别人的密码加密后的结果都是一样,那么,就会知道别人用的和自己就是同一个密码。   解决 加盐 对于这个问题其实只要稍微混淆一下就能防范住了,这在加密术语中称为“加盐”。 具体来说

Python 实现电子邮件加密技术解析与实用代码案例

在当今数字化时代,信息安全至关重要。电子邮件作为人们日常沟通的重要工具,其安全性不容忽视。本文将介绍电子邮件加密的相关内容,包括其优势、适用人群、可能存在的风险,以及如何选择合适的加密服务。同时,还将提供一个在 Python 程序中集成电子邮件加密服务的实用代码案例,并探讨电子邮件加密的替代方案。 电子邮件加密的优势主要体现在保密性、完整性、身份验证和合规性四个方面。通过加密,只有授权的收件人才

【HBZ分享】MYSLQ保存MD5值应该用varchar还是char?

结论 使用char是最好的,因为MD5是固定长度,而char也正是保存固定长度类型。 为什么固定长度用char保存更好? 首先char是固定长度的,比如char(10)保存10个字符,那么当保存abc这3个字符时,char依然会占用10个字符空间,剩下7个是空字符。而varchar(10)就只会占用3个字符。char是固定长度,varchar是可变长度,即varchar具体长度要根据实际存储

直接通过apk来查看签名文件MD5

在dos命令输入keytool -printcert -file C:\Users\1\Desktop\test\META-INF\CERT.RSA,然后回车即可。 C:\Users\1\Desktop\test\META-INF\CERT.RSA指的是apk文件中META-INF文件夹下CERT.RSA

Java加密技术相关

1、ECB加密模式是最简单的模式,每一个数据块之间没有任何关系。因此它不需要也不能使用IV(初始化向量:Initialization vector)。默认的加密模式就是ECB(直接使用"AES"获取算法时) 2、其它加密模式需要使用IV,IV的使用方式: IvParameterSpec iv = new IvParameterSpec(keyBytes); encypher.in

安卓APK重签名并查看MD5值-2024最新版

重签名 命令行运行: apksigner sign --ks your_keystore.jks --out output.apk input.apk 在这个命令中: –ks 或 --keystore 参数后面是你的keystore文件路径。 your_keystore.jks 是你的keystore文件。 –out 参数后面是输出的签名后的APK文件名。 output.apk 是输出的