Java的MD5加密和解密

简单demo:

Java代码  

  1. import  java.security.*;
  2. import  java.security.spec.*;
  3. class  MD5_test {
  4. public   final   static  String MD5(String s) {
  5. char  hexDigits[] = {  ‘0‘ ,  ‘1‘ ,  ‘2‘ ,  ‘3‘ ,  ‘4‘ ,  ‘5‘ ,  ‘6‘ ,  ‘7‘ ,  ‘8‘ ,  ‘9‘ ,
  6. ‘a‘ ,  ‘b‘ ,  ‘c‘ ,  ‘d‘ ,  ‘e‘ ,  ‘f‘  };
  7. try  {
  8. byte [] strTemp = s.getBytes();
  9. MessageDigest mdTemp = MessageDigest.getInstance("MD5" );
  10. mdTemp.update(strTemp);
  11. byte [] md = mdTemp.digest();
  12. int  j = md.length;
  13. char  str[] =  new   char [j *  2 ];
  14. int  k =  0 ;
  15. for  ( int  i =  0 ; i < j; i++) {
  16. byte  byte0 = md[i];
  17. str[k++] = hexDigits[byte0 >>> 4  &  0xf ];
  18. str[k++] = hexDigits[byte0 & 0xf ];
  19. }
  20. return   new  String(str);
  21. } catch  (Exception e) {
  22. return   null ;
  23. }
  24. }
  25. public   static   void  main(String[] args) {
  26. // MD5_Test aa = new MD5_Test();
  27. System.out.print(MD5_test.MD5("b" ));
  28. }
  29. }

[java] view plain copy print?

  1. import java.security.*;
  2. import java.security.spec.*;
  3. class MD5_test {
  4. public final static String MD5(String s) {
  5. char hexDigits[] = { ‘0‘, ‘1‘, ‘2‘, ‘3‘, ‘4‘, ‘5‘, ‘6‘, ‘7‘, ‘8‘, ‘9‘,
  6. ‘a‘, ‘b‘, ‘c‘, ‘d‘, ‘e‘, ‘f‘ };
  7. try {
  8. byte[] strTemp = s.getBytes();
  9. MessageDigest mdTemp = MessageDigest.getInstance("MD5");
  10. mdTemp.update(strTemp);
  11. byte[] md = mdTemp.digest();
  12. int j = md.length;
  13. char str[] = new char[j * 2];
  14. int k = 0;
  15. for (int i = 0; i < j; i++) {
  16. byte byte0 = md[i];
  17. str[k++] = hexDigits[byte0 >>> 4 & 0xf];
  18. str[k++] = hexDigits[byte0 & 0xf];
  19. }
  20. return new String(str);
  21. } catch (Exception e) {
  22. return null;
  23. }
  24. }
  25. public static void main(String[] args) {
  26. // MD5_Test aa = new MD5_Test();
  27. System.out.print(MD5_test.MD5("b"));
  28. }
  29. }

Java代码  

  1. import  java.security.MessageDigest;
  2. public   class  MD5andKL {
  3. // MD5加码。32位
  4. public   static  String MD5(String inStr) {
  5. MessageDigest md5 = null ;
  6. try  {
  7. md5 = MessageDigest.getInstance("MD5" );
  8. } catch  (Exception e) {
  9. System.out.println(e.toString());
  10. e.printStackTrace();
  11. return   "" ;
  12. }
  13. char [] charArray = inStr.toCharArray();
  14. byte [] byteArray =  new   byte [charArray.length];
  15. for  ( int  i =  0 ; i < charArray.length; i++)
  16. byteArray[i] = (byte ) charArray[i];
  17. byte [] md5Bytes = md5.digest(byteArray);
  18. StringBuffer hexValue = new  StringBuffer();
  19. for  ( int  i =  0 ; i < md5Bytes.length; i++) {
  20. int  val = (( int ) md5Bytes[i]) &  0xff ;
  21. if  (val <  16 )
  22. hexValue.append("0" );
  23. hexValue.append(Integer.toHexString(val));
  24. }
  25. return  hexValue.toString();
  26. }
  27. // 可逆的加密算法
  28. public   static  String KL(String inStr) {
  29. // String s = new String(inStr);
  30. char [] a = inStr.toCharArray();
  31. for  ( int  i =  0 ; i < a.length; i++) {
  32. a[i] = (char ) (a[i] ^  ‘t‘ );
  33. }
  34. String s = new  String(a);
  35. return  s;
  36. }
  37. // 加密后解密
  38. public   static  String JM(String inStr) {
  39. char [] a = inStr.toCharArray();
  40. for  ( int  i =  0 ; i < a.length; i++) {
  41. a[i] = (char ) (a[i] ^  ‘t‘ );
  42. }
  43. String k = new  String(a);
  44. return  k;
  45. }
  46. // 测试主函数
  47. public   static   void  main(String args[]) {
  48. String s = new  String( "a" );
  49. System.out.println("原始:"  + s);
  50. System.out.println("MD5后:"  + MD5(s));
  51. System.out.println("MD5后再加密:"  + KL(MD5(s)));
  52. System.out.println("解密为MD5后的:"  + JM(KL(MD5(s))));
  53. }
  54. }

[java] view plain copy print?

  1. import java.security.MessageDigest;
  2. public class MD5andKL {
  3. // MD5加码。32位
  4. public static String MD5(String inStr) {
  5. MessageDigest md5 = null;
  6. try {
  7. md5 = MessageDigest.getInstance("MD5");
  8. } catch (Exception e) {
  9. System.out.println(e.toString());
  10. e.printStackTrace();
  11. return "";
  12. }
  13. char[] charArray = inStr.toCharArray();
  14. byte[] byteArray = new byte[charArray.length];
  15. for (int i = 0; i < charArray.length; i++)
  16. byteArray[i] = (byte) charArray[i];
  17. byte[] md5Bytes = md5.digest(byteArray);
  18. StringBuffer hexValue = new StringBuffer();
  19. for (int i = 0; i < md5Bytes.length; i++) {
  20. int val = ((int) md5Bytes[i]) & 0xff;
  21. if (val < 16)
  22. hexValue.append("0");
  23. hexValue.append(Integer.toHexString(val));
  24. }
  25. return hexValue.toString();
  26. }
  27. // 可逆的加密算法
  28. public static String KL(String inStr) {
  29. // String s = new String(inStr);
  30. char[] a = inStr.toCharArray();
  31. for (int i = 0; i < a.length; i++) {
  32. a[i] = (char) (a[i] ^ ‘t‘);
  33. }
  34. String s = new String(a);
  35. return s;
  36. }
  37. // 加密后解密
  38. public static String JM(String inStr) {
  39. char[] a = inStr.toCharArray();
  40. for (int i = 0; i < a.length; i++) {
  41. a[i] = (char) (a[i] ^ ‘t‘);
  42. }
  43. String k = new String(a);
  44. return k;
  45. }
  46. // 测试主函数
  47. public static void main(String args[]) {
  48. String s = new String("a");
  49. System.out.println("原始:" + s);
  50. System.out.println("MD5后:" + MD5(s));
  51. System.out.println("MD5后再加密:" + KL(MD5(s)));
  52. System.out.println("解密为MD5后的:" + JM(KL(MD5(s))));
  53. }
  54. }
时间: 2024-10-25 07:28:48

Java的MD5加密和解密的相关文章

Java实现MD5加密及解密的代码实例分享

链接:http://www.jb51.net/article/86027.htm Java实现MD5加密及解密的代码实例分享 作者:厦门大学陈黎栋 字体:[增加 减小] 类型:转载 时间:2016-06-07我要评论 如果对安全性的需求不是太高,MD5仍是使用非常方便和普及的加密方式,比如Java中自带的MessageDigest类就提供了支持,这里就为大家带来Java实现MD5加密及解密的代码实例分享: 基础:MessageDigest类的使用 其实要在Java中完成MD5加密,Message

h5棋牌源码租用Java的MD5加密和解密类

理解MD5MD5的应用非常广泛h5棋牌源码租用(h5.hxforum.com)联系170618633533企鹅2952777280(http://yhgj8004.com)源码出售 房卡出售 后台出租联系方式只有企鹅.例如我们在unix中下载某种软件时,常常会看到一个扩展名为.md5的文件,内容大概是:MD5 (tanajiya.tar.gz) = 0ca175b9c0f726a831d895e269332461这就是tanajiya.tar.gz文件的数字签名.因此当我们得到这个文件后,使用工

iOS,一行代码进行RSA、DES 、AES、MD5加密、解密

最近做了一个移动项目,是有服务器和客户端类型的项目,客户端是要登录才行的,服务器也会返回数据,服务器是用Java开发的,客户端要同时支持多平台(Android.iOS),在处理iOS的数据加密的时候遇到了一些问题.起初采取的方案是DES加密,老大说DES加密是对称的,网络抓包加上反编译可能会被破解,故采取RSA方式加密.RSA加密时需要公钥和私钥,客户端保存公钥加密数据,服务器保存私钥解密数据.(iOS端公钥加密私钥解密.java端公钥加密私钥解密,java端私钥加密公钥解密都容易做到,iOS不

Java中的加密与解密

Java中的加密与解密主要对数据的安全性提供保障,分为对称和非对称的,对称表示加密密钥和解密密钥是同一个密钥,因此也常常称作私密密钥或秘密密钥,非对称密钥表示加密密钥和解密为两个不同的密钥,一个为公共密钥,另一个则为私密密钥.对称加密解密算法有DES.AES等,非对称加密解密算法有RSA.DH等.对于数据的加密与解密我们通常通过生成密钥,然后通过加密与解密操作类利用密钥对数据进行加密与解密,接下来我们看看Java中如何实现对称.非对称加密与解密. 对称加密与解密:通过KeyGenerator(密

asp.net中实现MD5加密、解密的方法

这个MD5加密.解密的方法会使用即可. 使用时的代码备忘:Response.Write(FormsAuthentication.HashPasswordForStoringInConfigFile("要加密的字符串", "MD5")); 以下是加密.解密的代码部分: /*用法 protected void Page_Load(object sender, EventArgs e) { //加密 this.Title = CEncrypt.DesEncrypt(&qu

java 采用MD5加密解密

MD5加密解密 package endecrypt; import java.io.UnsupportedEncodingException; import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; /** * 采用MD5加密解密 * @author tfq * @datetime 2011-10-13 */ public class MD5Util { /*** * MD5加码 生成3

java实现DES加密与解密,md5加密

很多时候要对秘要进行持久化加密,此时的加密采用md5.采用对称加密的时候就采用DES方法了 1 import java.io.IOException; 2 import java.security.MessageDigest; 3 import java.security.SecureRandom; 4 5 import javax.crypto.Cipher; 6 import javax.crypto.SecretKey; 7 import javax.crypto.SecretKeyFac

Java实现MD5加密和文件校验

MD5简介: MD5的全称:Message-Digest Algorithm 5(信息-摘要算法5) MD5的加密方式是一种哈希加密.一些主流的编程语言都已经实现了MD5的加密,所以如果你的程序或是系统涉及到在多种语言之间的校验,那么MD5可以是备选之一.不过因为MD5是采用哈希函数来进行的加密,所以它无关密钥,也就是说在确定了明文的情况下,MD5就可以加密.不过MD5是不可逆的,只能加密,不能解密. MD5加密字符串: public class Md5Util { // 标准的构造函数,调用m

AES —— JAVA中对称加密和解密

package demo.security; import java.io.IOException; import java.io.UnsupportedEncodingException; import java.security.InvalidKeyException; import java.security.NoSuchAlgorithmException; import java.security.SecureRandom; import java.util.Base64; impor