链接:http://www.cnblogs.com/android-blogs/p/5305598.html

Java的MD5加密和解密

简单demo:

  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. }
  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. }
  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. }
  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的MD5加密和解密的更多相关文章

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

    链接:http://www.jb51.net/article/86027.htm Java实现MD5加密及解密的代码实例分享 作者:厦门大学陈黎栋 字体:[增加 减小] 类型:转载 时间:2016-0 ...

  2. java 实现md5加密的三种方式与解密

      java 实现md5加密的三种方式 CreateTime--2018年5月31日15点04分 Author:Marydon 一.解密 说明:截止文章发布,Java没有实现解密,但是已有网站可以免费 ...

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

    本文为投稿文章,作者:Flying_Einstein(简书) 加密的Demo,欢迎下载 JAVA端的加密解密,读者可以看我同事的这篇文章:http://www.jianshu.com/p/98569e ...

  4. Java生成MD5加密字符串代码实例

    这篇文章主要介绍了Java生成MD5加密字符串代码实例,本文对MD5的作用作了一些介绍,然后给出了Java下生成MD5加密字符串的代码示例,需要的朋友可以参考下   (1)一般使用的数据库中都会保存用 ...

  5. Java C# MD5 加密串一致性

    Java C# MD5 加密串一致性   Java public final static String md5(String s) { char hexDigits[] = { '0', '1',  ...

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

    这个MD5加密.解密的方法会使用即可. 使用时的代码备忘:Response.Write(FormsAuthentication.HashPasswordForStoringInConfigFile(& ...

  7. 使用JAVA进行MD5加密后所遇到的一些问题

    前言:这几天在研究apache shiro如何使用,这好用到了给密码加密的地方,就碰巧研究了下java的MD5加密是如何实现的,下面记录下我遇到的一些小问题. 使用java进行MD5加密非常的简单,代 ...

  8. Java实现MD5加密_字符串加密_文件加密

    Java实现MD5加密,具体代码如下: package com.bstek.tools; import java.io.FileInputStream; import java.io.IOExcept ...

  9. SELECT INTO和INSERT INTO SELECT的区别 类似aaa?a=1&b=2&c=3&d=4,如何将问号以后的数据变为键值对 C# 获取一定区间的随即数 0、1两个值除随机数以外的取值方法(0、1两个值被取值的概率相等) C# MD5 加密,解密 C#中DataTable删除多条数据

    SELECT INTO和INSERT INTO SELECT的区别   数据库中的数据复制备份 SELECT INTO: 形式: SELECT value1,value2,value3 INTO Ta ...

随机推荐

  1. getSqlMapClientTemplate().insert()方法的返回值问题

    insert方法的返回值     今天碰到一个问题,就是关于ibatis的insert方法的返回值的问题.在网上找了很多例子,自己也亲自试了一下. 最后得出结论:insert方法返回的是在表中插入记录 ...

  2. 通过 Docker Compose 组合 ASP NET Core 和 SQL Server

    目录 Docker Compose 简介 安装 WebApi 项目 创建项目 编写Dockfile Web MVC 项目 创建项目 编写Dockfile 编写 docker-compose.yml文件 ...

  3. ASP.NET Core 集成 WebSocket

    1. 环境 AspNetCore Web 2.0 (MVC) Windows 10 IIS 10 Express/IIS VS 2017 2.如何配置 在已有的或者新创建的 AspNet Core M ...

  4. Abschlussarbeit:Konstruktion und Implementierung von Dota2 Datenbank Intelligent Verwaltungsplatfom

    1.Die Hintergrund und Bedeutung des Themas Dank nicht ausreichendes Erkenntnisse der Spielplanner un ...

  5. [PY3]——内置数据结构(1)——列表及其常用操作

    列表及其常用操作_xmind图         about列表 列表是一个序列,用于顺序存储数据 列表分为两种:ArrayList(用数组实现).LinkedList(用链表实现) 定义与初始化 #l ...

  6. 转载:BIO | NIO | AIO

    http://my.oschina.net/bluesky0leon/blog/132361 也谈BIO | NIO | AIO (Java版)   转载自:zheng-lee博客 发布时间: 201 ...

  7. nodejs学习笔记四(模块化、在npm上发布自己的模块)

    模块化:      1.系统模块:  http.querystring.url      2.自定义模块      3.包管理器   [系统模块]   Assert      断言:肯定确定会出现的情 ...

  8. iOS语音播报文字

    记得大学的时候学微软Window Phone时,有语音识别类似苹果的嘿,Siri.今天无聊百度搜了一下,搜到苹果语音播报文字.自己试了下还挺好玩. 1.引入框架#import <AVFounda ...

  9. s:iterator的用法

    truts2的s:iterator 可以遍历 数据栈里面的任何数组,集合等等以下几个简单的demo: s:iterator 标签有3个属性:     value:被迭代的集合     id   :指定 ...

  10. scala笔记,主要摘自网络教程

    1.scala是一种纯面向对象的语言,每个值都是对象.对象的数据类型以及行为由类和特质描述 2.类的扩展有2种机制:继承和混入机制 3.scala是一种函数式语言,其函数也能当成值来使用 ==4.sc ...