简易加密工具类

来源:互联网 发布: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
原创粉丝点击