Android MD5,3DES,AES,RSA,Base64加解密

本文详细介绍了Android中数据加密的几种常见方式,包括MD5单向加密、3DES对称加密、AES对称加密以及RSA非对称加密。同时,提到了Base64编码在数据传输中的应用。文章通过实例展示了如何使用这些加密算法,以确保数据在客户端与服务器间安全交互。
摘要由CSDN通过智能技术生成

导言:
由于数据的安全性,所以需要进行数据加密和解密处理,所以本文只是记录一点

名词:
对称加密算法:加密和解密使用相同密钥的算法
异或加密算法:简单加密算法的一种,通过异或算法处理
RSA:公钥和私钥,非对称密码算法
Des:密钥加载,对称加密算法
Des3:DES加密算法的扩展,它使用3条64位的密钥对数据进行三次加密,DES向AES过渡的加密算法
Aes:区块,对称加密算法,用来替代Des
Md5:单向不可逆加密算法,但是也是可以编译的,用跑字典,解决方式多次加密和加盐
SHA:单向不可逆加密算法,Md5后继者,有SHA-1,SHA-2(SHA-224、SHA-384,SHA-512),如Google将使用SHA-2
Base64:对数据内容进行编码转换适合网络传输,由于传输过程中那些不可见ascii码被处理错误

步骤:
1:MD5加密,很简单,直接将需要加密的字符串传入即可.


public static String MD5Tool(String str) {
        if (TextUtils.isEmpty(str)) {
            return "";
        }
        try {
            MessageDigest mDigest = MessageDigest.getInstance("MD5");
            byte[] bytes = mDigest.digest(str.getBytes());
            String result = "";
            for (byte bt : bytes) {
                String temp = Integer.toHexString(bt & 0xff);
                if (temp.length() == 1) {
                    temp = "0" + temp;
                }
                result += temp;
            }
            return result;
        } catch (Exception e) {
            e.printStackTrace();
        }
        return "";
    }

2:3DES重要加密解密类


public class DES3Util {
    private static final String TYPE = "DESede";

    //加密
    public static byte[] encryptMode(byte[] keybyte, byte[] src) {
        try {
            SecretKey deskey = new SecretKeySpec(keybyte, TYPE);
            Cipher c1 = Cipher.getInstance(TYPE);
            c1.init(Cipher.ENCRYPT_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;
    }

    //解密
    public static byte[] decryptMode(byte[] keybyte, byte[] src) {
        try {
            SecretKey deskey = new SecretKeySpec(keybyte, TYPE);
            Cipher c1 = Cipher.getInstance(TYPE);
            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;
    }

    //byte->hexString
    public static String byte2hex(byte[] b) {
        String hs = "";
        String stmp = "";
        for (int n = 0; n < b.length; n++) {
            stmp = (java.lang.Integer.toHexString(b[n] & 0XFF));
            if (stmp.length() == 1) hs = hs + "0" + stmp;
            else hs = hs + stmp;
            if (n < b.length - 1) hs = hs + "";
        }
        return hs.toUpperCase();
    }

    //hexString->byte
    public static byte[] hexStringToBytes(Stri
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值