详见:http://blog.yemou.net/article/query/info/tytfjhfascvhzxcyt165

DES 支持8位加密解密,3Des支持24位,Aes支持32位。3Des是Des算法做三次。位数的单位是字节byte,不是bits。

3Des是把24位分成3组,第一组八位用来加密,第二组8位用于解密,第三组8位用于加密,所以,如果秘钥为123456781234567812345678(3组1-8),则相当于做了一次12345678的Des加密。例如:第一次用12345678秘钥对123进行加密得到 "LDiFUdf0iew=",然后用第二组的12345678对其进行解密(逆向加密过程),得到了123,第三次又一次加密得到 "LDiFUdf0iew="。

三种加密方式代码里不同的地方:

byte temp[] = new byte[位数];

SecretKey des_key = new SecretKeySpec(temp, "加密算法");

加密算法名对应的是:Aes Des Desede

改了这两个地方就可以实现不同加密方式。加密方式底层不一样,DES是把原文编程2进制的一串01,然后和密文做运算,交换什么什么位置。

[java] view plaincopyprint?

  1. public class MainActivity extends Activity implements OnClickListener {

  2. private EditText des_key, des_src, des_dst;

  3. private Button btn_encode, btn_decode;

  4. @Override

  5. protected void onCreate(Bundle savedInstanceState) {

  6. super.onCreate(savedInstanceState);

  7. setContentView(R.layout.activity_main);

  8. des_key = (EditText) findViewById(R.id.des_key);

  9. des_src = (EditText) findViewById(R.id.des_src);

  10. des_dst = (EditText) findViewById(R.id.des_dst);

  11. btn_encode = (Button) findViewById(R.id.btn_encode);

  12. btn_decode = (Button) findViewById(R.id.btn_decode);

  13. btn_encode.setOnClickListener(this);

  14. btn_decode.setOnClickListener(this);

  15. }

  16. @Override

  17. public void onClick(View v) {

  18. String key_str = des_key.getText().toString();

  19. if (!TextUtils.isEmpty(key_str)) {

  20. try {

  21. // DES不管长了短了,都变成八位

  22. // AES 长度变为128 new SecretKeySpec(temp, "Aes");

  23. // 3Des 长度变为24 new SecretKeySpec(temp, "Desced");

  24. byte temp[] = new byte[8];

  25. byte b[] = key_str.getBytes("UTF-8");

  26. System.arraycopy(b, 0, temp, 0, Math.min(b.length, temp.length));

  27. // Des只支持八位

  28. SecretKey des_key = new SecretKeySpec(temp, "Des");

  29. Cipher cipher = Cipher.getInstance("Des");

  30. switch (v.getId()) {

  31. case R.id.btn_encode:

  32. String src_str = des_src.getText().toString();

  33. if (!TextUtils.isEmpty(src_str)) {

  34. cipher.init(Cipher.ENCRYPT_MODE, des_key);

  35. byte[] bytes = cipher

  36. .doFinal(src_str.getBytes("UTF-8"));

  37. // 是用Base64编码的二进制字节数组

  38. des_dst.setText(Base64.encodeToString(bytes,

  39. Base64.DEFAULT));

  40. }

  41. break;

  42. case R.id.btn_decode:

  43. String dst_str = des_dst.getText().toString();

  44. if (!TextUtils.isEmpty(dst_str)) {

  45. cipher.init(Cipher.DECRYPT_MODE, des_key);

  46. // 是用Base64编码的二进制字节数组

  47. byte[] bytes = cipher.doFinal(Base64.decode(dst_str,

  48. Base64.DEFAULT));

  49. des_src.setText(new String(bytes, "UTF-8"));

  50. }

  51. break;

  52. }

  53. } catch (Exception e) {

  54. e.printStackTrace();

  55. }

  56. }

  57. }

  58. }


布局:

[java] view plaincopyprint?

  1. <span style="font-size:18px;"><LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"

  2. xmlns:tools="http://schemas.android.com/tools"

  3. android:layout_width="match_parent"

  4. android:layout_height="match_parent"

  5. android:orientation="vertical" >

  6. <EditText

  7. android:id="@+id/des_key"

  8. android:layout_width="wrap_content"

  9. android:layout_height="wrap_content"

  10. android:hint="秘钥" />

  11. <EditText

  12. android:id="@+id/des_src"

  13. android:layout_width="wrap_content"

  14. android:layout_height="wrap_content"

  15. android:hint="原文" />

  16. <EditText

  17. android:id="@+id/des_dst"

  18. android:layout_width="wrap_content"

  19. android:layout_height="wrap_content"

  20. android:hint="密文" />

  21. <Button

  22. android:id="@+id/btn_encode"

  23. android:layout_width="wrap_content"

  24. android:layout_height="wrap_content"

  25. android:text="加密" />

  26. <Button

  27. android:id="@+id/btn_decode"

  28. android:layout_width="wrap_content"

  29. android:layout_height="wrap_content"

  30. android:text="解密" />

  31. </LinearLayout></span>

DES、3DES、AES加密方式的更多相关文章

  1. [android]DES/3DES/AES加密方式

    DES 支持8位加密解密,3Des支持24位,Aes支持32位.3Des是Des算法做三次.位数的单位是字节byte.不是bits. 3Des是把24位分成3组.第一组八位用来加密,第二组8位用于解密 ...

  2. Java利用DES/3DES/AES这三种算法分别实现对称加密

    转载地址:http://blog.csdn.net/smartbetter/article/details/54017759 有两句话是这么说的: 1)算法和数据结构就是编程的一个重要部分,你若失掉了 ...

  3. DES/3DES/AES 三种对称加密算法实现

    1. 简单介绍 3DES(或称为Triple DES)是三重数据加密算法(TDEA,Triple Data Encryption Algorithm)块密码的通称.它相当于是对每个数据块应用三次DES ...

  4. C#中使用DES和AES加密解密

    C#中使用DES和AES加密解密 2008-01-12 09:37 using System;using System.Text;using System.Security.Cryptography; ...

  5. 对加密的了解(DES/3DES/AES区别 )

    DES 1977年1月,美国政府颁布:采纳IBM公司设计的方案作为非机密数据的正式. 目前在国内,随着三金工程尤其是金卡工程的启动,DES算法在POS.ATM.磁卡及智能卡(IC卡).加油站.高速公路 ...

  6. java-信息安全(二)-对称加密算法DES,3DES,AES,Blowfish,RC2,RC4

    概述 信息安全基本概念: DES(Data Encryption Standard,数据加密标准) 3DES(Triple DES,三重数据加密算法(TDEA,Triple Data Encrypti ...

  7. DES/3DES/AES区别

    公元前400年,古希腊人发明了置换密码.1881年世界上的第一个电话保密专利出现.在第二次世界大战期间,德国军方启用“恩尼格玛”密码机,密码学在战争中起着非常重要的作用. DES 1977年1月,美国 ...

  8. 两种JavaScript的AES加密方式(可与Java相互加解密)

    由于JavaScript属于弱类型脚本语言,因此当其与强类型的后台语言进行数据交互时会产生各种问题,特别是加解密的操作.本人由于工作中遇到用js与Java进行相互加解密的问题,在网上查了很多资料及代码 ...

  9. go加密算法:CBC对称加密(一)--3DES/AES

    其实对称加密中的:DES\3DES\AES 采取的加解密步骤一致,只是小的细节不太一样.大家多看看就能写出来了 // rsao1.go package main import ( "byte ...

随机推荐

  1. NLPIR大数据挖掘平台新增敏感词扫描功能

    在网络日益发达的现在,也伴随着有益信息与造成不稳定因素的信息也随之日益泛滥,为了网民的思想健康,也为了社会的和谐,在许多对外公共场合下,有些内容是要经过审查才能显示的.在网络审查初期,都是通过人工审核 ...

  2. Hbase集群监控

    Hbase集群监控 Hbase Jmx监控 监控每个regionServer的总请求数,readRequestsCount,writeRequestCount,region分裂,region合并,St ...

  3. openstack中dashboard页面RuntimeError: Unable to create a new session key. It is likely that the cache is unavailable.

    环境是centos7,直接跑在服务器上. 按照官网一步步安装openstack,到验证dashborad时出错. 登录http://192.168.1.73/dashboard ,输入域名,用户名,密 ...

  4. testbench中$display查看例化model里面信号方法以及$realtime用法

    前言 此为测试语法,不可综合: 流程: 1.在tb中可以这么写,检测clk_t_en的高电平,输出仿真时间位置,想查看的cnt_t是底层模块中的.这么会使得时间延迟一个周期: always @(pos ...

  5. 错误 0xc0202049: 数据流任务 1: 无法在只读列“ID”中插入数据

    数据库导入导出时总失败,错误信息如下: 正在验证 (错误) 消息错误 0xc0202049: 数据流任务 1: 无法在只读列“ID”中插入数据. (SQL Server 导入和导出向导) 错误 0xc ...

  6. IOS中的单例设计模式

    单例设计模式是IOS开发中一种很重要很常用的一种设计模式.它的设计原理是无论请求多少次,始终返回一个实例,也就是一个类只有一个实例.下面是苹果官方文档中关于单例模式的图片: 如图所示,左边的图是默认的 ...

  7. rtems的GNU(GCC)编译环境配置

    // 创建目录 /home/shael/rtems/build   //存放解压包和编译包目录 /home/shael/rtems/archive   //存放源码包目录 /home/shael/rt ...

  8. 实现Echarts折线图的虚实转换

    需求:医院的体温单,在统计体温时,对于正常情况下统计的体温数据,需要显示实线:对于进行物理降温后统计的体温数据,需要显示虚线. 现有的体温单是运用 Echarts 折线图,统一用实线显示.因此在这基础 ...

  9. vue插件编写与实战

    关于 微信公众号:前端呼啦圈(Love-FED) 我的博客:劳卜的博客 知乎专栏:前端呼啦圈 前言 热爱vue开发的同学肯定知道awesome-vue 这个github地址,里面包含了数以千计的vue ...

  10. JavaWeb(五)Filter过滤器

    Filter过滤器 Fileter介绍 Filter也称之为过滤器,它是Servlet技术中最实用的技术,WEB开发人员通过Filter技术,对web服务器管理的所有web资源:例如Jsp, Serv ...