用户密码MD5和SHA加密
来源:互联网 发布:网络连接错误 编辑:程序博客网 时间:2024/05/22 06:27
今天在项目中接触到了用户密码加密,在之前做一些简单的小项目根本没有考虑到数据库的安全性。其实在真正的项目中就得需要对用户密码加密。才真正了解了一下用户密码的加密。
用户密码的加密技术有很多,加密级别也有很多。我今天接触了MD5技术和SHA技术
MD5
md5的作用原理就是把你输入你用户密码转化成32位乱的数字和字符。并且它是一个不可逆的字符串变换算法换句话说就是,即使你看到源程序和算法描述,也无法将一个MD5的值变换回原始的字符串,从数学原理上说,是因为原始的字符串有无穷多个,这有点象不存在反函数的数学函数。
MD5 (tanajiya.tar.gz) = 0ca175b9c0f726a831d895e269332461
SHA的工作原理很像的。SHA 同样也是一个系列,它包括 SHA-1,SHA-224,SHA-256,SHA-384,和 SHA-512 等几种算法。其中,SHA-1,SHA-224 和 SHA-256 适用于长度不超过 2^64 二进制位的消息。SHA-384 和 SHA-512 适用于长度不超过 2^128 二进制位的消息。
package am.util;
import java.io.UnsupportedEncodingException;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
/**
* 加密工具类
*
* md5加密出来的长度是32位
*
* sha加密出来的长度是40位
*
* @author am
*
*/
public class Encrypt {
/** * 加密 * * @param inputText * @return */public static String e(String inputText) { return md5(inputText);}/** * 二次加密,应该破解不了了吧? * * @param inputText * @return */public static String md5AndSha(String inputText) { return sha(md5(inputText));}/** * md5加密 * * @param inputText * @return */public static String md5(String inputText) { return encrypt(inputText, "md5");}/** * sha加密 * * @param inputText * @return */public static String sha(String inputText) { return encrypt(inputText, "sha-1");}/** * md5或者sha-1加密 * * @param inputText * 要加密的内容 * @param algorithmName * 加密算法名称:md5或者sha-1,不区分大小写 * @return */private static String encrypt(String inputText, String algorithmName) { if (inputText == null || "".equals(inputText.trim())) { throw new IllegalArgumentException("请输入要加密的内容"); } if (algorithmName == null || "".equals(algorithmName.trim())) { algorithmName = "md5"; } String encryptText = null; try { MessageDigest m = MessageDigest.getInstance(algorithmName); m.update(inputText.getBytes("UTF8")); byte s[] = m.digest(); // m.digest(inputText.getBytes("UTF8")); return hex(s); } catch (NoSuchAlgorithmException e) { e.printStackTrace(); } catch (UnsupportedEncodingException e) { e.printStackTrace(); } return encryptText;}/** * 返回十六进制字符串 * * @param arr * @return */private static String hex(byte[] arr) { StringBuffer sb = new StringBuffer(); for (int i = 0; i < arr.length; ++i) { sb.append(Integer.toHexString((arr[i] & 0xFF) | 0x100).substring(1, 3)); } return sb.toString();}
}
- 用户密码MD5和SHA加密
- MD5和SHA加密
- MD5和SHA加密
- md5加密和sha加密的使用
- iOS MD5加密和SHA-1加密
- 实现MD5和SHA加密的类
- IOS md5 和 sha哈希加密
- java中MD5和SHA加密
- 使用MD5和SHA算法加密信息
- MD5/SHA 加密处理
- MD5+SHA+BASE64加密
- 加密之SHA,MD5
- android md5加密和sha-1加密方法
- MD5加密与SHA加密
- 用md5加密用户密码
- 使用MD5加密用户密码
- oracle 用户密码md5加密
- MD5 用户密码加密
- 数据库设计 资源表与资源收藏表的设计
- NOIP 2017总结
- 010_LeetCode_10 Regular Expression Matching 题解
- Linux下的Minicom
- 【算法题】KMP算法应用:二叉树结构匹配
- 用户密码MD5和SHA加密
- 超详细Retrofit源码解析(二)
- Java——HashMap原理
- STM32的USART讲解
- 判断在一个矩阵中是否存在一条包含某字符串所有字符的路径。(回溯法)
- 优先级队列
- DNS主从服务器配置及案例解析
- 新装MySQL的一系列问题
- android开发之路(1)-- 支付宝SDK集成