网络安全之MD5/SHA1

MD5

首先,我们简单介绍一下MD5.
在正常的开发中,在登录的时候用到MD5消息摘要算法较为多.
MD5就像每一人的指纹一样是独一无二的,不同的数据加密后的结果是不一样的.
不过相同的数据加密后的结果是一样的.开发人员用它来进行密码加密存到数据库中,每次登陆将密码加密后与数据库中的密码进行比对.
MD5它是不可逆的,不过现在的技术讷讷够进行破解.
MD5:消息摘要算法第五版,之前还有MD2,MD4等.
用于一致性校验.就拿文件来说吧,如果文件被改动那么MD5也会随之改变.判断下载的文件是否被篡改.
还可用于数字签名,安全访问认证(数据库密码)等.
*算法原理:***MD5以512位分组来处理输入的信息,且每一分组又被划分为16个32位子分组,经过了一系列的处理后,算法的输出由四个32位分组组成,将这四个32位分组级联后将生成一个128位散列值.
MD5,SHA1:属于散列算法,不可逆.
MD5使用很简单:

 public static void MD5Encrypt(String data) throws NoSuchAlgorithmException {
        StringBuffer  ensryptStr = new StringBuffer();
        MessageDigest digest = MessageDigest.getInstance("MD5");
        digest.update(data.getBytes());
        byte[] cipher = digest.digest();
        for (byte b : cipher) {
            //转换为16进制
            String hexStr = Integer.toHexString(b & 0xff);
            ensryptStr.append(hexStr.length() == 1 ? "0" + hexStr : hexStr);
        }
        System.out.println(ensryptStr.toString());
        System.out.println("c4ca4238a0b923820dcc509a6f75849b");
    }


    public static void main(String[] args) throws NoSuchAlgorithmException {
      MD5Encrypt("1");

    }

SHA1

SHA1:shA1也是散列加密.全名:安全哈希加密算法(Secure Hash Algorithm)主要用于数字签名.

 public static void sha1Encrypt(String str) throws NoSuchAlgorithmException {
        MessageDigest messageDigest = MessageDigest.getInstance("SHA1");
        messageDigest.update(str.getBytes());
        byte[] cipher = messageDigest.digest();
        String a = "";
        for (byte b : cipher) {
            String hex = Integer.toHexString(b & 0xff);
            a += (hex.length() == 1 ? "0" + hex : hex);
        }
        System.out.println(a);

    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值