当前位置:首页 > Android > 正文内容

【Android工具类】比DES加密更安全的算法——3DES加密算法

jsc9年前 (2016-09-19)Android3689

    在前面的文章里面,我们讨论了DES算法,同时也明白了如何才能保证不同平台下的加密和解密结果的一致性。但是DES作为出现了很长时间的一种加密算法,随着计算机运算能力的加强,DES加密容易被暴力破解,其安全性变得有点低。于是,为了增强数据的安全性,3DES算法就应运而生了。

    3DES,顾名思义,就是对DES加密算法的改进,3DES通过对每个数据进行3次DES加密,从而降低被破解的可能性。

     如果我们要使用3DES加密,需要以下几个步骤


    ①传入共同约定的密钥(keyBytes)以及算法(Algorithm),来构建SecretKey密钥对象

        SecretKey deskey = new SecretKeySpec(keyBytes, Algorithm);    

    ②根据算法实例化Cipher对象。它负责加密/解密

        Cipher c1 = Cipher.getInstance(Algorithm);    

    ③传入加密/解密模式以及SecretKey密钥对象,实例化Cipher对象

        c1.init(Cipher.ENCRYPT_MODE, deskey);    

    ④传入字节数组,调用Cipher.doFinal()方法,实现加密/解密,并返回一个byte字节数组

        c1.doFinal(src);

   

    具体的代码实现过程如下

package com.qust;  
  
import java.io.UnsupportedEncodingException;  
  
import javax.crypto.Cipher;  
import javax.crypto.SecretKey;  
import javax.crypto.spec.SecretKeySpec;  
  
/** 
 *  
 * @ClassName: com.qust.SecretUtils 
 * @Description: 3DES加密解密工具类 
 * @author zhaokaiqiang 
 * @date 2014-11-13 下午11:28:14 
 *  
 */  
public class DES3Utils {  
  
    // 定义加密算法,DESede即3DES  
    private static final String Algorithm = "DESede";  
    // 加密密钥  
    private static final String PASSWORD_CRYPT_KEY = "zhaokaiqiang1992";  
  
    /** 
     * 加密方法 
     *  
     * @param src 
     *            源数据的字节数组 
     * @return 
     */  
    public static byte[] encryptMode(byte[] src) {  
        try {  
            // 生成密钥  
            SecretKey deskey = new SecretKeySpec(  
                    build3DesKey(PASSWORD_CRYPT_KEY), Algorithm);  
            // 实例化Cipher  
            Cipher cipher = Cipher.getInstance(Algorithm);  
            cipher.init(Cipher.ENCRYPT_MODE, deskey);  
            return cipher.doFinal(src);  
        } catch (java.security.NoSuchAlgorithmException e1) {  
            e1.printStackTrace();  
        } catch (javax.crypto.NoSuchPaddingException e2) {  
            e2.printStackTrace();  
        } catch (java.lang.Exception e3) {  
            e3.printStackTrace();  
        }  
        return null;  
    }  
  
    /** 
     * 解密函数 
     *  
     * @param src 
     *            密文的字节数组 
     * @return 
     */  
    public static byte[] decryptMode(byte[] src) {  
        try {  
            SecretKey deskey = new SecretKeySpec(  
                    build3DesKey(PASSWORD_CRYPT_KEY), Algorithm);  
            Cipher c1 = Cipher.getInstance(Algorithm);  
            c1.init(Cipher.DECRYPT_MODE, deskey);  
            return c1.doFinal(src);  
        } catch (java.security.NoSuchAlgorithmException e1) {  
            e1.printStackTrace();  
        } catch (javax.crypto.NoSuchPaddingException e2) {  
            e2.printStackTrace();  
        } catch (java.lang.Exception e3) {  
            e3.printStackTrace();  
        }  
        return null;  
    }  
  
    /** 
     * 根据字符串生成密钥24位的字节数组 
     *  
     * @param keyStr 
     * @return 
     * @throws UnsupportedEncodingException 
     */  
    public static byte[] build3DesKey(String keyStr)  
            throws UnsupportedEncodingException {  
        byte[] key = new byte[24];  
        byte[] temp = keyStr.getBytes("UTF-8");  
  
        if (key.length > temp.length) {  
            System.arraycopy(temp, 0, key, 0, temp.length);  
        } else {  
            System.arraycopy(temp, 0, key, 0, key.length);  
        }  
        return key;  
    }  
}

测试类的代码如下

package com.qust;  
  
public class Main {  
  
    public static void main(String[] args) {  
        String msg = "使用3DES对数据进行加密";  
        System.out.println("【加密前】:" + msg);  
  
        // 加密  
        byte[] secretArr = DES3Utils.encryptMode(msg.getBytes());  
        System.out.println("【加密后】:" + new String(secretArr));  
  
        // 解密  
        byte[] myMsgArr = DES3Utils.decryptMode(secretArr);  
        System.out.println("【解密后】:" + new String(myMsgArr));  
    }  
}

  转载请注明出处:http://blog.csdn.net/zhaokaiqiang1992

扫描二维码推送至手机访问。

版权声明:本文由微小站发布,如需转载请注明出处。

本文链接:https://jsc0.com/post/119.html

标签: DES加密3DES
分享给朋友:

“【Android工具类】比DES加密更安全的算法——3DES加密算法” 的相关文章

使用自定义RadioButton和ViewPager实现TabHost效果和带滑动的页卡效果。

使用自定义RadioButton和ViewPager实现TabHost效果和带滑动的页卡效果。

在工作中又很多需求都不是android系统自带的控件可以达到效果的,内置的TabHost就是,只能达到简单的效果 ,所以这个时候就要自定义控件来达到效果:这个效果就是: 使用自定义RadioButton和ViewPager实现TabHost带滑动的页卡效果。    &...

Android权限问题整理

Android权限系统非常庞大,我们在Android系统中做任何操作都需要首先获取Android系统权限,本文记录了所有的Android权限问题,整理一下分享给大家。访问登记属性 android.permission.ACCESS_CHECKIN_PROPERTIES读取或写入登记check-in数...

Fragment生命周期

Fragment生命周期

onAttach方法:Fragment和Activity建立关联的时候调用。onCreateView方法:为Fragment加载布局时调用。onActivityCreated方法:当Activity中的onCreate方法执行完后调用。onDestroyView方法:Fragment中的布局被移除时...

创建Popwindow弹出菜单的两种方式

创建Popwindow弹出菜单的两种方式

方法一的Activity package com.app.test02; import android.app.Activity; import android.os.Bundle; import android.view.Gravity; import android.v...

下拉刷新及滚动到底部加载更多的Listview使用

下拉刷新及滚动到底部加载更多的Listview使用

本文主要介绍可同时实现下拉刷新及滑动到底部加载更多的ListView的使用。 该ListView优点包括:a. 可自定义下拉响应事件(如下拉刷新)  b.可自定义滚动到底部响应的事件(如滑动到底部加载更多)  c.可自定义丰富的样式  d....

Android中的消息通知(NotificationManager和Notification)

下面来谈谈notification,这个notification一般用在电话,短信,邮件,闹钟铃声,在手机的状态栏上就会出现一个小图标,提 示用户处理这个通知,这时手从上方滑动状态栏就可以展开并处理这个快讯。已添加的Notification.Builder,使其更容易构建通知。 notifica...