网络安全之MD5/SHA1

来源:互联网 发布:yy摇骰子软件 编辑:程序博客网 时间:2024/06/16 04:46

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);    }
原创粉丝点击