[Android Pro] AES加密

简介:

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

复制代码
package com.secufity.aes;

import java.util.UUID;

import javax.crypto.Cipher; import javax.crypto.spec.IvParameterSpec; import javax.crypto.spec.SecretKeySpec; import com.secufity.db.Base64; /** * * @author wfung_kwok * */ public class AES { static String e = "9238513401340235"; // 加密 public static String Encrypt(String src, String key) throws Exception { if (key == null) { System.out.print("Key为空null"); return null; } // 判断Key是否为16位 if (key.length() != 16) { System.out.print("Key长度不是16位"); return null; } byte[] raw = key.getBytes(); SecretKeySpec skeySpec = new SecretKeySpec(raw, "AES"); Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5Padding");// "算法/模式/补码方式"0102030405060708 IvParameterSpec iv = new IvParameterSpec(e.getBytes());// 使用CBC模式,需要一个向量iv,可增加加密算法的强度  cipher.init(Cipher.ENCRYPT_MODE, skeySpec, iv); byte[] encrypted = cipher.doFinal(src.getBytes()); return Base64.encodeBytes(encrypted); // 此处使用BASE64做转码功能,同时能起到2次加密的作用。  } // 解密 public static String Decrypt(String src, String key) throws Exception { try { // 判断Key是否正确 if (key == null) { System.out.print("Key为空null"); return null; } // 判断Key是否为16位 if (key.length() != 16) { System.out.print("Key长度不是16位"); return null; } byte[] raw = key.getBytes("ASCII"); SecretKeySpec skeySpec = new SecretKeySpec(raw, "AES"); Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5Padding"); IvParameterSpec iv = new IvParameterSpec(e.getBytes()); cipher.init(Cipher.DECRYPT_MODE, skeySpec, iv); byte[] encrypted1 = Base64.decode(src);// 先用base64解密 try { byte[] original = cipher.doFinal(encrypted1); String originalString = new String(original); return originalString; } catch (Exception e) { System.out.println(e.toString()); return null; } } catch (Exception ex) { System.out.println(ex.toString()); return null; } } public static void main(String[] args) throws Exception { String key = UUID.randomUUID().toString().substring(0, 16); String src = "Email : wfung_kwok@xxx.com"; System.out.println(src); // 加密 long start = System.currentTimeMillis(); String enString = AES.Encrypt(src, key); System.out.println("加密后的字串是:" + enString); long useTime = System.currentTimeMillis() - start; System.out.println("加密耗时:" + useTime + "毫秒"); // 解密 start = System.currentTimeMillis(); String DeString = AES.Decrypt(enString, key); System.out.println("解密后的字串是:" + DeString); useTime = System.currentTimeMillis() - start; System.out.println("解密耗时:" + useTime + "毫秒"); } }
复制代码

Console:

Email : wfung_kwok@xxx.com
加密后的字串是:Gkl3xEIHndI1W8CN9fKbvEM3Fzo9KJSfVvQPWRkH0WI=
加密耗时:234毫秒
解密后的字串是:Email : wfung_kwok@xxx.com
解密耗时:0毫秒

 

本文转自demoblog博客园博客,原文链接http://www.cnblogs.com/0616--ataozhijia/p/5253481.html如需转载请自行联系原作者

demoblog
相关文章
|
1月前
|
Linux 数据安全/隐私保护 Windows
aes加密在linux下会生成随机key的解决办法
aes加密在linux下会生成随机key的解决办法
16 2
|
2月前
|
PHP 数据安全/隐私保护
在PHP中使用AES进行加密和解密
在PHP中使用AES进行加密和解密
|
3月前
|
存储 算法 安全
【加密算法】AES对称加密算法简介
【加密算法】AES对称加密算法简介
|
3月前
|
安全 小程序 数据安全/隐私保护
aes加密算法python版本
aes加密算法python版本
39 0
|
4月前
|
算法 安全 物联网
全面了解AES加密:入门指南(二)
全面了解AES加密:入门指南
|
3月前
|
算法 Android开发
安卓逆向 -- 自吐算法(3DES和AES)
安卓逆向 -- 自吐算法(3DES和AES)
20 1
|
4月前
|
存储 安全 算法
全面了解AES加密:入门指南(一)
全面了解AES加密:入门指南
|
算法 Java Android开发
Android中常用的加密方式
Android面试的时候,尤其是面试一些金融公司的时候经常性的问道:“你会不会加密?”,“加密方式是什么?”,“大概什么样的加密原理呢?”。其实,大多数人都是一脸懵逼,我也懵逼过。
1111 0
|
8天前
|
消息中间件 网络协议 Java
Android 开发中实现数据传递:广播和Handler
Android 开发中实现数据传递:广播和Handler
13 1
|
10天前
|
Linux 编译器 Android开发
FFmpeg开发笔记(九)Linux交叉编译Android的x265库
在Linux环境下,本文指导如何交叉编译x265的so库以适应Android。首先,需安装cmake和下载android-ndk-r21e。接着,下载x265源码,修改crosscompile.cmake的编译器设置。配置x265源码,使用指定的NDK路径,并在配置界面修改相关选项。随后,修改编译规则,编译并安装x265,调整pc描述文件并更新PKG_CONFIG_PATH。最后,修改FFmpeg配置脚本启用x265支持,编译安装FFmpeg,将生成的so文件导入Android工程,调整gradle配置以确保顺利运行。
32 1
FFmpeg开发笔记(九)Linux交叉编译Android的x265库