单向加密------SHA-1

5 篇文章 0 订阅
2 篇文章 0 订阅

概念

安全哈希算法(Secure Hash Algorithm)主要适用于数字签名标准(Digital Signature Standard DSS)里面定义的数字签名算法(Digital Signature Algorithm DSA)。

源码

如下为SHA-1加解密的Java实现:

package cn.silence.encrypt;

import java.security.MessageDigest;

/**
 * Created by Silence on 2017/12/18.
 * SHA-1是SHA的升级版本,是一项单向加密技术,如MD5,生成不可逆的结果,可用于验证签名领域
 */
public class SHACoder {

    /**
     * 定义加密方式为SHA-1
     */
    private final static String KEY_SHA_1 = "SHA-1";

    /**
     * 全局数组
     */
    private final static String[] hexDigits = {"0", "1", "2", "3", "4", "5", "6", "7", "8", "9", "a", "b", "c", "d", "e", "f"};

    /**
     * 用SHA-1加密数据
     * @param data      原始数据
     * @return byte[]   加密后数据
     * @throws Exception
     */
    public static byte[] encrypt(byte[] data) throws Exception {

        //MessageDigest为应用程序提供信息摘要算法的功能,如MD5和SHA
        MessageDigest sha = MessageDigest.getInstance(KEY_SHA_1);

        //使用指定的字节数组更新摘要
        sha.update(data);

        //完成摘要Hash计算,调用此方法后,摘要被重置
        return sha.digest();

    }

    /**
     * 用SHA-1加密数据
     * @param data      原始数据
     * @return String   加密后数据
     * @throws Exception
     */
    public static String encrypt(String data) throws Exception {

        //验证传入参数,如果为空直接返回
        if (data == null || "".equals(data)) {
            return "";
        }

        //MessageDigest为应用程序提供信息摘要算法的功能,如MD5和SHA
        MessageDigest sha = MessageDigest.getInstance(KEY_SHA_1);

        //使用指定的字节数组更新摘要
        sha.update(data.getBytes());

        //完成摘要Hash计算,调用此方法后,摘要被重置
        byte[] bytes = sha.digest();

        //将摘要变成十六进制字符串返回
        return byteArrayToHexString(bytes);

    }

    /**
     * 将字节转化成十六进制形式的字符串
     * @param b         字节
     * @return String   字符串
     */
    private static String byteToHexString(byte b) {

        int ret = b;

        if (ret < 0) {
            ret += 256;
        }

        int m = ret / 16;
        int n = ret % 16;

        return hexDigits[m] + hexDigits[n];

    }

    /**
     * 将字节数组转化为十六进制形式的字符串
     * @param bytes     字节数组
     * @return String   字符串
     */
    private static String byteArrayToHexString(byte[] bytes) {

        StringBuffer sb = new StringBuffer();

        for (int i = 0; i < bytes.length; i++) {
            sb.append(byteToHexString(bytes[i]));
        }

        return sb.toString();

    }

}

测试

package cn.silence.encrypt;

/**
 * Created by Silence on 2017/12/18.
 */
public class main {

    public static void main(String[] args) throws Exception {

        String result = SHACoder.encrypt("测试");

        System.out.println(result);

    }

}

总结

SHA-1是一种数据加密算法,该算法的思想是接收一段明文,然后以一种不可逆的方式将它转换成一段(通常更小)密文,也可以简单的理解为取一串输入码(称为预映射或信息),并把它们转化为长度较短、位数固定的输出序列即散列值(也称为信息摘要或信息认证代码)的过程。

鸣谢

非常感谢百度百科

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值