热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

AndroidAES加解密工具类

AES对称加密算法高级加密标准(英语:AdvancedEncryptionStandard,缩写:AES)&

AES对称加密算法


  • 高级加密标准(英语:Advanced Encryption Standard,缩写:AES),在密码学中又称Rijndael加密法,是美国联邦政府采用的一种区块加密标准。这个标准用来替代原先的DES,已经被多方分析且广为全世界所使用

 


AES加密工具类参考,需要根据项目的实际情况改动配置。


code注释完美,请慢用 O(∩_∩)O


import java.util.Base64;
import java.util.Locale;import javax.crypto.Cipher;
import javax.crypto.spec.IvParameterSpec;
import javax.crypto.spec.SecretKeySpec;/*** AES加密解密字符串工具类** 背景:MD5加密不可逆的特性决定了在很多场景下并不适用。如在某些需要对加密后的密文进行解密使之可读的场景下,就需要使用可逆加密算法实现!* 常用的可逆加密算法有:AES对称加密算法与RSA非对称加密算法** 概述:* 高级加密标准(英语:Advanced Encryption Standard,缩写:AES),在密码学中又称Rijndael加密法,是美国联邦政府采用的一种区块加密标准。* 这个标准用来替代原先的DES,已经被多方分析且广为全世界所使用,是对称密钥加密中最流行的算法之一;* 工作模式包括:ECB、CBC、CTR、OFB、CFB;* 使用范围:该工具类仅支持CBC模式下的:* 填充:PKCS7PADDING* 数据块:128位* 密码(key):32字节长度(例如:12345678901234567890123456789012)* 偏移量(iv):16字节长度(例如:1234567890123456)* 输出:hex* 字符集:UTF-8* 使用方式:String encrypt = AESCBCUtil.encrypt("wy");* String decrypt = AESCBCUtil.decrypt(encrypt);* 验证方式:http://tool.chacuo.net/cryptaes(在线AES加密解密)*/
public class AESUtil {//示例:密码private static final String key = "12345678901234567890123456789012";//示例:iv偏移量private static final String iv = "1234567890123456";/*** 算法/模式/填充*/private final static String CIPHER_MODE_PADDING = "AES/CBC/PKCS7PADDING";/*** 服务端约定的盐值*/private static final String AES_SALT = "请向后端开发人员要";/*** 获取密钥信息* 每个场景需求不一样,此处规则可由你们自己设计** @param timestamp 时间戳* AES密钥:md5(timestamp+salt),取前16位做为AES密钥* Iv:md5后16位做为AES偏移量* @return MD5加密后的密钥信息,32位小写*/public static String getSecretKeyInfo(String timestamp) {return MD5Utils.MD5(timestamp + AES_SALT);}/*** 加密:对字符串进行加密** @param encryptStr 需要加密的字符串* @param secretKey 密钥* @param iv iv偏移量* @return 加密后的字符串*/public static String encrypt(String encryptStr, String secretKey, String iv) {String encryptedPassword = "";try {//创建AES秘钥SecretKeySpec skeySpec = new SecretKeySpec(secretKey.getBytes("UTF-8"), "AES");// 创建密码器Cipher cipher = Cipher.getInstance(CIPHER_MODE_PADDING);IvParameterSpec ivParameterSpec = new IvParameterSpec(iv.getBytes("UTF-8"));cipher.init(Cipher.ENCRYPT_MODE, skeySpec, ivParameterSpec);// 加密byte[] encrypted = cipher.doFinal(encryptStr.getBytes());encryptedPassword = Base64Encoder.encode(encrypted);return encryptedPassword;} catch (Exception ex) {ex.printStackTrace();}return encryptedPassword;}/*** 解密:对加密后的字符串进行解密,并返回字符串** @param encryptedStr 需要解密的字符串* @return 解密后的字符串*/public static String decrypt(String encryptedStr) {try {//创建AES秘钥SecretKeySpec skeySpec = new SecretKeySpec(key.getBytes("UTF-8"), "AES");// 创建密码器Cipher cipher = Cipher.getInstance(CIPHER_MODE_PADDING);IvParameterSpec ivParameterSpec = new IvParameterSpec(iv.getBytes("UTF-8"));cipher.init(Cipher.DECRYPT_MODE, skeySpec, ivParameterSpec);// 解密
// byte[] bytes = hexStr2Bytes(encryptedStr);byte[] bytes = Base64Decoder.decodeToBytes(encryptedStr);byte[] original = cipher.doFinal(bytes);return new String(original);} catch (Exception ex) {ex.printStackTrace();}return null;}}

 

注意事项:

1,移动端和服务端的加解密需保持一致

2,秘钥和iv偏移量的生成规则前后端约定一致

3,加密需要的盐值可直接由服务端开发人员设计好,提供给移动端开发人员

4,ASE加密规则设计后端人员定好,

     比如这样定:【AES加密模式:CBC  填充:PKCS7    偏移量:Iv  数据块:128位  输出:base64  字符集:UTF-8】

 

 


推荐阅读
  • 开发笔记:加密&json&StringIO模块&BytesIO模块
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了加密&json&StringIO模块&BytesIO模块相关的知识,希望对你有一定的参考价值。一、加密加密 ... [详细]
  • 本文介绍了Java工具类库Hutool,该工具包封装了对文件、流、加密解密、转码、正则、线程、XML等JDK方法的封装,并提供了各种Util工具类。同时,还介绍了Hutool的组件,包括动态代理、布隆过滤、缓存、定时任务等功能。该工具包可以简化Java代码,提高开发效率。 ... [详细]
  • 本文介绍了南邮ctf-web的writeup,包括签到题和md5 collision。在CTF比赛和渗透测试中,可以通过查看源代码、代码注释、页面隐藏元素、超链接和HTTP响应头部来寻找flag或提示信息。利用PHP弱类型,可以发现md5('QNKCDZO')='0e830400451993494058024219903391'和md5('240610708')='0e462097431906509019562988736854'。 ... [详细]
  • 先看官方文档TheJavaTutorialshavebeenwrittenforJDK8.Examplesandpracticesdescribedinthispagedontta ... [详细]
  • 超级简单加解密工具的方案和功能
    本文介绍了一个超级简单的加解密工具的方案和功能。该工具可以读取文件头,并根据特定长度进行加密,加密后将加密部分写入源文件。同时,该工具也支持解密操作。加密和解密过程是可逆的。本文还提到了一些相关的功能和使用方法,并给出了Python代码示例。 ... [详细]
  • JVM 学习总结(三)——对象存活判定算法的两种实现
    本文介绍了垃圾收集器在回收堆内存前确定对象存活的两种算法:引用计数算法和可达性分析算法。引用计数算法通过计数器判定对象是否存活,虽然简单高效,但无法解决循环引用的问题;可达性分析算法通过判断对象是否可达来确定存活对象,是主流的Java虚拟机内存管理算法。 ... [详细]
  • 本文详细介绍了Java中vector的使用方法和相关知识,包括vector类的功能、构造方法和使用注意事项。通过使用vector类,可以方便地实现动态数组的功能,并且可以随意插入不同类型的对象,进行查找、插入和删除操作。这篇文章对于需要频繁进行查找、插入和删除操作的情况下,使用vector类是一个很好的选择。 ... [详细]
  • Java中包装类的设计原因以及操作方法
    本文主要介绍了Java中设计包装类的原因以及操作方法。在Java中,除了对象类型,还有八大基本类型,为了将基本类型转换成对象,Java引入了包装类。文章通过介绍包装类的定义和实现,解答了为什么需要包装类的问题,并提供了简单易用的操作方法。通过本文的学习,读者可以更好地理解和应用Java中的包装类。 ... [详细]
  • JDK源码学习之HashTable(附带面试题)的学习笔记
    本文介绍了JDK源码学习之HashTable(附带面试题)的学习笔记,包括HashTable的定义、数据类型、与HashMap的关系和区别。文章提供了干货,并附带了其他相关主题的学习笔记。 ... [详细]
  • 本文介绍了Swing组件的用法,重点讲解了图标接口的定义和创建方法。图标接口用来将图标与各种组件相关联,可以是简单的绘画或使用磁盘上的GIF格式图像。文章详细介绍了图标接口的属性和绘制方法,并给出了一个菱形图标的实现示例。该示例可以配置图标的尺寸、颜色和填充状态。 ... [详细]
  • 欢乐的票圈重构之旅——RecyclerView的头尾布局增加
    项目重构的Git地址:https:github.comrazerdpFriendCircletreemain-dev项目同步更新的文集:http:www.jianshu.comno ... [详细]
  • GreenDAO快速入门
    前言之前在自己做项目的时候,用到了GreenDAO数据库,其实对于数据库辅助工具库从OrmLite,到litePal再到GreenDAO,总是在不停的切换,但是没有真正去了解他们的 ... [详细]
  • Java 11相对于Java 8,OptaPlanner性能提升有多大?
    本文通过基准测试比较了Java 11和Java 8对OptaPlanner的性能提升。测试结果表明,在相同的硬件环境下,Java 11相对于Java 8在垃圾回收方面表现更好,从而提升了OptaPlanner的性能。 ... [详细]
  • 本文整理了Java面试中常见的问题及相关概念的解析,包括HashMap中为什么重写equals还要重写hashcode、map的分类和常见情况、final关键字的用法、Synchronized和lock的区别、volatile的介绍、Syncronized锁的作用、构造函数和构造函数重载的概念、方法覆盖和方法重载的区别、反射获取和设置对象私有字段的值的方法、通过反射创建对象的方式以及内部类的详解。 ... [详细]
  • 2021最新总结网易/腾讯/CVTE/字节面经分享(附答案解析)
    本文分享作者在2021年面试网易、腾讯、CVTE和字节等大型互联网企业的经历和问题,包括稳定性设计、数据库优化、分布式锁的设计等内容。同时提供了大厂最新面试真题笔记,并附带答案解析。 ... [详细]
author-avatar
A_2na轻奢主义总店访烟
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有