reference to : http://blog.csdn.net/wfung_kwok/article/details/7766029

加密和解密要用同一個key

AES:

  1. import java.util.UUID;
  2.  
  3. import javax.crypto.Cipher;
  4. import javax.crypto.spec.IvParameterSpec;
  5. import javax.crypto.spec.SecretKeySpec;
  6.  
  7. public class DES {
  8.  
  9. private static final byte[] iv = { 1, 2, 3, 4, 5, 6, 7, 8 };
  10.  
  11. /**
  12. *
  13. * @param encryptString 加密内容
  14. * @param encryptKey 加密key
  15. * @return
  16. * @throws Exception
  17. */
  18. public static String encryptDES(String encryptString, String encryptKey)
  19. throws Exception {
  20. IvParameterSpec zeroIv = new IvParameterSpec(iv);
  21. SecretKeySpec key = new SecretKeySpec(encryptKey.getBytes(), "DES");
  22. Cipher cipher = Cipher.getInstance("DES/CBC/PKCS5Padding");
  23. cipher.init(Cipher.ENCRYPT_MODE, key, zeroIv);
  24. String tmp = Base64.encodeBytes(encryptString.getBytes("UTF-8"));
  25. byte[] encryptedData = cipher.doFinal(tmp.getBytes("UTF-8"));
  26. return Base64.encodeBytes(encryptedData);
  27. }
  28.  
  29. /**
  30. *
  31. * @param decryptString 解密内容
  32. * @param encryptKey 解密key
  33. * @return
  34. * @throws Exception
  35. */
  36. public static String decryptDES(String decryptString,String encryptKey)throws Exception {
  37. IvParameterSpec zeroIv = new IvParameterSpec(iv);
  38. SecretKeySpec key = new SecretKeySpec(encryptKey.getBytes(), "DES");
  39. Cipher cipher = Cipher.getInstance("DES/CBC/PKCS5Padding");
  40. cipher.init(Cipher.DECRYPT_MODE, key, zeroIv);
  41. byte[] decryptBytes = cipher.doFinal(Base64.decode(decryptString));
  42. String tmp = new String(decryptBytes,"UTF-8");
  43. return new String(Base64.decode(tmp));
  44. }
  45.  
  46. public static String getKey(){
  47. String p = UUID.randomUUID().toString();
  48. return SHA1.Encrypt(p).substring(0, 8);
  49. }
  50.  
  51. }

Test:

  1. public static void testDES() throws Exception{
  2.  
  3. String content = "AES加密";
  4. String key = DES.getKey();
  5. String a = DES.encryptDES(content, key);
  6. System.out.println("DES Encrypt..." + a);
  7. String b = DES.decryptDES(a, key);
  8. System.out.println("DES decrypt..." + b);
  9. }

Console:

  1. DES Encrypt...93koM7boCXsNrH91Y0MDJA==
  2. DES decrypt...AES加密

[Android Pro] DES加密 version1的更多相关文章

  1. Android:DES加密

    private static final String KEY = "xxxxxx"; // KEY的字节长度必须超过24 public DESUtil(){ super(); } ...

  2. [Android Pro] AES加密

    reference to :http://blog.csdn.net/wfung_kwok/article/details/7766427 package com.secufity.aes; impo ...

  3. Android数据加密之Des加密

    前言: 端午节前有个同事咨询我有关Android DES加密的相关实现,简单的实现了一下,今天来总结一下. 其他几种加密方式: Android数据加密之Rsa加密 Android数据加密之Aes加密 ...

  4. Android和java平台 DES加密解密互通程序及其不能互通的原因

    网上的demo一搜一大堆,但是,基本上都是一知半解(包括我).为什么呢?我在尝试分别在两个平台加密的时候,竟然发现Android DES 加密和java DES加密的程序不能互通.就是加密的结果不一样 ...

  5. Android DES加密的CBC模式加密解密和ECB模式加密解密

    DES加密共有四种模式:电子密码本模式(ECB).加密分组链接模式(CBC).加密反馈模式(CFB)和输出反馈模式(OFB). CBC模式加密: import java.security.Key; i ...

  6. Android客户端与服务器端通过DES加密认证

    转载地址:http://blog.csdn.net/spring21st/article/details/6730283 由于Android应用没有像web开发中的session机制,所以采用PHPS ...

  7. 【Android工具类】怎样保证Android与server的DES加密保持一致

    转载请注明出处:http://blog.csdn.net/zhaokaiqiang1992 在我们的应用程序涉及到比較敏感的数据的时候,我们一般会对数据进行简单的加密.在与server之间的数据交互中 ...

  8. android -------- DES加密解密算法

    DES全称为Data Encryption Standard,即数据加密标准,是一种使用密钥加密的块算法,1977年被美国联邦政府的国家标准局确定为联邦资料处理标准(FIPS),并授权在非密级政府通信 ...

  9. (iOS)Base64加密和DES加密、以及JAVA和iOS中DES加密统一性问题

    我们在项目中为了安全方面的考虑,通常情况下会选择一种加密方式对需要安全性的文本进行加密,而Base64加密和DES64加密是常用的加密算法.我记得我在前一个项目中使用的就是这两种加密算法的结合:Bas ...

随机推荐

  1. 如何禁用wordpress的RSS Feed

    RSS(Really Simple Syndication)是一种描述和同步网站内容的格式,早期使用RSS订阅能更快地获取信息,网站提供RSS输出,有利于让用户获取网站内容的最新更新.但随着采集技术的 ...

  2. asp.net的sql防注入和去除html标记的方法

    一. // <summary> /// 过滤标记 /// </summary> /// <param name="NoHTML">包括HTML, ...

  3. java使用split分隔,需要注意的点

    String severName = "10.6.62.244"; System.out.println(severName.split(".").length ...

  4. [Asp.net MVC]Asp.net MVC5系列——从控制器访问模型中的数据

    目录 概述 从控制器访问模型中的数据 强类型模型与@model关键字 总结 系列文章 [Asp.net MVC]Asp.net MVC5系列——第一个项目 [Asp.net MVC]Asp.net M ...

  5. OpenCV图像的缩放

    函数介绍:    1.cvResize 改变图像大小     void cvResize(const CvArr *src, CvArr *dst, int interpolation)    函数说 ...

  6. 关于vco

    关于vco:vco是vSphere 4开始,在vCenter中默认附件安装的一个新组件.它的作用主要是提供工作流管理.这么说可能有些抽象,让人搞不明白vco到底是做什么用的.其实很简单,以前的vCen ...

  7. 2015安徽省赛 J.镜像树

    http://xcacm.hfut.edu.cn/problem.php?id=1214 乱搞题 数组+结构体 递归遍历 #include<iostream> #include<cs ...

  8. 51Nod 1766 树上的最远点对

    Description 一棵树,询问两个端点编号分别在在 \([a,b]\) 和 \([c,d]\) 两个区间中的最长链. Sol 线段树+ST表. 树上最长链可以合并,只需要合并两个区间最长链的两个 ...

  9. JavaScript Coding 模式荟萃

    1.自运行的匿名函数 <script type="text/javascript" src="./js/jquery-1.7.2.js"></ ...

  10. 深度分析Linux下双网卡绑定七种模式 多网卡的7种bond模式原理

    http://blog.csdn.net/abc_ii/article/details/9991845多网卡的7种bond模式原理 Linux网卡绑定mode共有七种(~) bond0.bond1.b ...