zoukankan      html  css  js  c++  java
  • Java加密算法

    Java加密算法有三种:

    1、单向加密算法

    2、对错加密算法

    3、非对称加密算法 

    单向加密算法

    单向加密是不可逆的加密算法,加密的密文不能解密,常见的算法有MD5、SHA、HMAC。

    MD5(信息摘要算法)

    无论多长数据最后都编码成128位数据,同样数据一直一致。

    用途:可用做文件校验、密码加密、散列数据。

    代码:

    public static String getMD5Str(String s) {
        try {
            MessageDigest md = MessageDigest.getInstance("MD5");
            byte[] bytes = md.digest(s.getBytes("utf-8"));
            return toHex(bytes);
        }
        catch (Exception e) {
            throw new RuntimeException(e);
        }
    }
    public static String toHex(byte[] bytes) {
        final char[] HEX_DIGITS = "0123456789ABCDEF".toCharArray();
        StringBuilder ret = new StringBuilder(bytes.length * 2);
        for (int i=0; i<bytes.length; i++) {
            ret.append(HEX_DIGITS[(bytes[i] >> 4) & 0x0f]);
            ret.append(HEX_DIGITS[bytes[i] & 0x0f]);
        }
        return ret.toString();
    }
    
    public static void main(String[] args) {
        System.out.println(getMD5Str("123456")); //输出E10ADC3949BA59ABBE56E057F20F883E
    }
    View Code

    注意:

    1、算出的字符串长度32,每个字符都是一个十六进制的数,一个十六进制的数转换成二进制是四位,也就是32长度的字符串换算成位32 * 4 = 128位。

    2、算出的一定是32个字符的,16个是截取了结果一部分的。

    3、MD5常配合base64编码用,但base64编码不是一种加密算法,只是一种数据编码。

    SHA(安全散列算法)

    安全性高于MD5,加密结果都是160位数据,用途与MD5类似。

    SHA家族的五个算法,分别是SHA-1、SHA-224、SHA-256、SHA-384,和SHA-512,后四者有时并称为SHA-2。

    HMAC(散列消息鉴别码)

    用途:常用于对API参数进行请求校验。

    对称加密算法

    同一个密钥可加密,也可以解密,常见算法DES、AES、PBE。

    DES(数据加密标准)

    DES算法的入口参数有三个:Key、Data、Mode。其中Key为7个字节共56位,是DES算法的工作密钥;Data为8个字节64位,是要被加密或被解密的数据;Mode为DES的工作方式,有两种:加密或解密。

    AES(DES的升级版)

    PBE(基于口令加密)

    非对称加密算法

    需要两个密钥。公钥加密数据,私钥解密数据;私钥用来签名,公钥验证签名;常见算法RSA、DH。 

  • 相关阅读:
    机器学习 -- 用户画像
    机器学习 -- 分类
    机器学习 -- 聚类
    机器学习 -- 回归
    数据分析 -- 流程
    Nginx + Tomcat7 + redis session一致性问题
    机器学习 -- 信息论
    机器学习 -- 统计与分布
    ElasticSearch 学习一: 基本命令
    问题17:如何将多个小字符串拼接成一个大的字符串
  • 原文地址:https://www.cnblogs.com/lovesong/p/8964631.html
Copyright © 2011-2022 走看看