Java MD5加密与RSA加密

匿名 (未验证) 提交于 2019-12-02 21:53:52

区别:

  MD5加密:

    加密时通过原字符串加密成另一串字符串

    解密时需要原加密字符串进行重新加密比较两次加密结果是否一致

  T=RSA加密:

    加密时通过原字符串生成密钥对(公钥+私钥)

    解密时通过公钥和私钥进行解密,解密出原字符串进行比较是否一致

个人观点:

  RSA加密略比MD5加密牛逼一点点

废话不多说上栗子:

  MD5加密:

package cn.news.util;  import java.security.MessageDigest;  /**  *   * @author: 房上的猫  *   * @time: 2018年5月14日 下午8:04:44  *   * @博客地址: https://www.cnblogs.com/lsy131479/  *  */ public class MD5 {     private static String MD(String s) {         try {             MessageDigest md = MessageDigest.getInstance("MD5");             md.update(s.getBytes("utf-8"));             byte[] bytes = md.digest(s.getBytes("utf-8"));             return toHex(bytes);         } catch (Exception e) {             throw new RuntimeException(e);         }     }      private 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(MD("hello word"));     } }

结果:

RSA加密与解密:

package cn.news.util;  import java.security.KeyPair; import java.security.KeyPairGenerator; import java.security.PrivateKey; import java.security.PublicKey; import java.util.Base64;  import javax.crypto.Cipher;  /**  *   * @author: 房上的猫  *   * @time: 2018年5月14日 下午7:56:12  *   * @博客地址: https://www.cnblogs.com/lsy131479/  *  */ public class RSA {     public static String data = "hello world";      public static void main(String[] args) throws Exception {         // TODO Auto-generated method stub          KeyPair keyPair = genKeyPair(1024);          // 获取公钥,并以base64格式打印出来         PublicKey publicKey = keyPair.getPublic();         System.out.println("公钥:" + new String(Base64.getEncoder().encode(publicKey.getEncoded())));          // 获取私钥,并以base64格式打印出来         PrivateKey privateKey = keyPair.getPrivate();         System.out.println("私钥:" + new String(Base64.getEncoder().encode(privateKey.getEncoded())));          // 公钥加密         byte[] encryptedBytes = encrypt(data.getBytes(), publicKey);         System.out.println("加密后:" + new String(encryptedBytes));          // 私钥解密         byte[] decryptedBytes = decrypt(encryptedBytes, privateKey);         System.out.println("解密后:" + new String(decryptedBytes));     }      // 生成密钥对     public static KeyPair genKeyPair(int keyLength) throws Exception {         KeyPairGenerator keyPairGenerator = KeyPairGenerator.getInstance("RSA");         keyPairGenerator.initialize(1024);         return keyPairGenerator.generateKeyPair();     }      // 公钥加密     public static byte[] encrypt(byte[] content, PublicKey publicKey) throws Exception {         Cipher cipher = Cipher.getInstance("RSA");// java默认"RSA"="RSA/ECB/PKCS1Padding"         cipher.init(Cipher.ENCRYPT_MODE, publicKey);         return cipher.doFinal(content);     }      // 私钥解密     public static byte[] decrypt(byte[] content, PrivateKey privateKey) throws Exception {         Cipher cipher = Cipher.getInstance("RSA");         cipher.init(Cipher.DECRYPT_MODE, privateKey);         return cipher.doFinal(content);     } }

运行结果:

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!