简易加密工具类
来源:互联网 发布:linux认证工程师 编辑:程序博客网 时间:2024/05/16 04:50
一个简单的加密工具类,可以使自己写的登录密码加密后放入数据库,使别人在没有加密类时无法识别出密码,来保证自己密码的安全
package com.yc.jsp.util;import java.io.UnsupportedEncodingException;import java.security.MessageDigest;import java.security.NoSuchAlgorithmException;/** * 加密工具类 * md5加密出来的长度是32位 * sha加密出来的长度是40位 */public class Encrypt { /** * 测试 */ public static void main(String[] args) { /*// md5加密测试 String md5_1 = md5("a"); String md5_2 = md5("1"); //System.out.println(md5_1 + "\n" + md5_2); // sha加密测试 String sha_1 = sha("123456"); String sha_2 = sha("abc");*/ //System.out.println(sha_1 + "\n" + sha_2); System.out.println(Encrypt.md5AndSha("a")); //System.out.println(Encrypt.md5("12345678")); //System.out.println(Encrypt.sha("aaaaaaaa")); } /** * 加密 * * @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(); }}
测试方法已经写在代码中了。
0 0
- 简易加密工具类
- 简易加密工具
- 简易工具类笔记
- 简易Http工具类
- 发送广播简易工具类
- 工具类三:加密工具
- MD5 加密工具类
- java 加密工具类
- Java加密工具类
- java加密工具类
- Md5加密工具类
- MD5加密工具类
- AES加密工具类
- DES加密工具类
- 加密工具类 DESUtil
- MD5加密工具类
- 各种加密工具类
- java加密工具类
- 前端工程化的理解
- Spring JdbcTemplate方法详解
- 无论什么颜色的奖牌,都是无数汗水铸成的!
- 信号量 Semaphore
- TestNG中的组groups概念
- 简易加密工具类
- 关于扩展欧几里得算法的一些资料
- nand flash驱动的编写
- 微软面试百题002——返回优先级的栈
- 文章标题
- Java Exception 捕获和展示
- hdu 2841 Visible Trees 容斥,分解质因数
- SharedPreferences存储
- Three.js学习笔记---我和小伙伴都惊呆了