aes256加密java_使用Java和JCEKS进行AES-256加密

aes256加密java

总览

由于最近爱德华·斯诺登 ( Edward Snowden)发布了文件,以及针对JC Penny , Sony和Target等在线商业商店的黑客攻击激增,安全性已成为近年来讨论的重要话题。 尽管本文不会为您提供帮助防止使用非法来源数据的所有工具,但本文将为构建一套工具和策略提供起点,以帮助防止其他方使用数据。

这篇文章将展示如何在Java环境中对字符串采用AES加密。 它将讨论如何创建AES密钥以及以JCEKS密钥库格式存储AES密钥。 此博客中的代码的工作示例位于https://github.com/mike-ensor/aes-256-encryption-utility

建议按顺序阅读每个部分,因为每个部分都是前一部分的基础,但是,您可能希望快速跳转到特定部分。

  • 设置 –使用keytool设置和创建密钥
  • 加密 –使用byte []密钥加密消息
  • 解密 –使用相同的IV和加密密钥解密邮件
  • 从密钥库获取密钥 –通过别名从密钥库获取密钥

什么是JCEKS?

JCEKS代表的J avaçryptographyËxtensionķEY 小号扯了下来,这是针对Java平台的替代密钥库格式。 将密钥存储在KeyStore中可以作为一种措施,以防止暴露您的加密密钥。 Java密钥库安全地包含可以由别名引用以在Java程序中使用的各个证书和密钥。 Java KeyStore通常是使用Java JDK随附的“ keytool ”创建的。

注意:强烈建议为KeyStore创建复杂的密码,以确保内容安全。 KeyStore是一个被认为是公共文件,但是建议不要轻易访问该文件。

建立

所有加密均受每个国家/地区的法律管辖,并且通常会对加密强度进行限制。 一个例子是在美国,如果数据在边界外传输,则所有128位以上的加密都受到限制。 默认情况下,Java JCE实施强度策略以遵守这些规则。 如果首选更强的加密并遵守国家/地区的法律,则JCE需要访问更强的加密策略。 简而言之,如果您打算使用AES 256位加密,则必须安装Unlimited Strength Jurisdiction Policy Files 。 如果没有适当的策略,则无法进行256位加密。

安装JCE无限强度政策

这篇文章的重点是密钥,而不是JCE的安装和设置。 安装非常简单, 可以在此处找到明确的说明(注意:这是针对JDK7的,如果使用其他JDK,则搜索适当的JCE策略文件)。

密钥库设置

使用KeyTool时,操作密钥库很简单。 必须使用指向新密钥的链接或在导入现有密钥库的过程中创建密钥库。 为了创建一个新的密钥和密钥库,只需键入:

keytool -genseckey -keystore aes-keystore.jck -storetype jceks -storepass mystorepass -keyalg AES -keysize 256 -alias jceksaes -keypass mykeypass

重要标志

在上面的示例中,这里是有关keytool参数的说明:

密钥库参数

genseckey :生成SecretKey。 这是表示创建同步密钥的标志,它将成为我们的AES密钥 keystore密钥库的位置。 如果密钥库不存在,该工具将创建一个新的存储器。 路径可以是相对的或绝对的,但必须是局部的 storetype :这是商店的类型(JCE,PK12,JCEKS等)。 JCEKS用于存储证书中不包含的对称密钥(AES)。 storepass :与密钥库相关的密码。 强烈建议为密钥库创建一个强大的密码短语

关键参数

keyalg :用于创建密钥的算法(AES / DES / etc) keysize密钥的大小(128、192、256等) alias :给新创建的密钥的别名,使用该密钥时要在其中引用 keypass :保护密钥使用的密码

加密

由于它涉及Java中的数据,并且在最基本的级别上,加密是一种算法过程,用于通过可逆过程以编程方式混淆数据,双方都拥有与该数据有关的信息以及该算法的使用方式。 在Java加密中,这涉及使用密码。 JCE中的Cipher对象是通常由算法选择的加密提供程序的通用入口点。 此示例使用默认的Java提供程序,但也可以与Bouncy Castle一起使用。

生成密码对象

获取Cipher的实例非常容易,并且加密和解密都需要相同的过程。 (注意:加密和解密需要相同的算法,但不需要相同的对象实例)

Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5Padding");

一旦有了密码实例,就可以根据算法对数据进行加密和解密。 通常,该算法将需要其他信息,以便对数据进行加密/解密。 在此示例中,我们将需要向算法传递包含密钥和初始向量的字节(如下所述)。

初始化

为了使用密码,我们必须首先初始化密码。 此步骤是必需的,因此我们可以为算法提供其他信息,例如AES密钥和Initial Vector(又名IV)。

cipher.init(Cipher.ENCRYPT_MODE, secretKeySpecification, initialVector);

参量

SecretKeySpecification是一个对象,其中包含对构成AES密钥的字节的引用。 AES密钥无非是由密钥工具生成的(见上文)的特定大小的字节阵列(256位的AES 256或32个字节)。

替代参数

有多种创建密钥的方法,例如包含盐,用户名和密码(或类似名称)的哈希。 此方法将利用连接字符串的SHA1哈希,转换为字节,然后将结果截断为所需大小。 这篇文章不会显示使用此方法生成密钥或使用使用密码和密码的PBE密钥方法。 对于键输入密码和/或盐的使用是通过创建新的密钥的过程中使用的输入密钥工具处理。

初始化向量

AES算法还需要第二个参数,称为I信息V扇区。 该过程中使用IV来使加密的消息随机化,并防止密钥容易猜测。 IV被认为是公开共享的信息,但同样,不建议公开共享信息(例如,将其发布在您公司的网站上是不明智的)。 在加密消息时,通常会在消息前加上IV,因为基于算法,​​IV的大小将为设定值/已知大小。 注意:如果使用相同的IV,密钥和消息,则AES算法将输出相同的结果。 建议每次加密随机创建IV。

使用新初始化的密码,加密消息很简单。 只需致电:

byte[] encryptedMessageInBytes = Cipher.doFinal((message.getBytes("UTF-8"));
String base64EncodedEncryptedMsg = BaseEncoding.base64().encode(encryptedMessageInBytes);
String base32EncodedEncryptedMsg = BaseEncoding.base32().encode(encryptedMessageInBytes);

编码结果

字节数组很难可视化,因为它们通常不会在任何字符集中形成字符。 解决此问题的最佳建议是以HEX(base-16) , Double HEX(base-32)或Base64格式表示字节。 如果将通过URL或POST参数传递消息,请确保使用网络安全的Base64编码。 Google Guava库提供了出色的BaseEncoding实用程序 。 注意:请记住在解密之前对编码的消息进行解码。

解密

解密消息几乎与加密过程相反,只有少数例外。 与生成随机IV的加密过程不同,解密需要一个已知的初始化向量作为参数。

解密

解密时,请使用与加密方法相同的过程获得一个密码对象。 密码对象将需要利用完全相同的算法,包括方法和填充选择。 一旦代码获得对Cipher对象的引用,下一步就是初始化用于解密的密码,并将对密钥和初始化向量的引用传递给它。

// key is the same byte[] key used in encryption
SecretKeySpec secretKeySpecification = new SecretKeySpec(key, "AES");
cipher.init(Cipher.DECRYPT_MODE, secretKeySpecification, initialVector);

注意: 密钥存储在密钥库中,并通过使用别名获得 。 有关从密钥库获取密钥的详细信息,请参见下文

一旦提供了密钥IV并初始化了解密密码,密码就可以执行解密了。

byte[] encryptedTextBytes = BaseEncoding.base64().decode(message);
byte[] decryptedTextBytes = cipher.doFinal(encryptedTextBytes);
String origMessage = new String(decryptedTextBytes);

保持静脉输液的策略

用于加密消息的IV对于解密消息很重要,因此提出了一个问题,即它们如何保持在一起。 一种解决方案是对IV进行基本编码(请参见上文),并将其添加到经过加密和编码的消息之前:Base64UrlSafe(myIv)+分隔符+ Base64UrlSafe(encryptedMessage)。 其他可能的解决方案可能是上下文相关的,例如,在具有IV的XML文件中包括一个属性,并为所使用的密钥提供别名。

从密钥库获取密钥

这篇文章的开头显示了创建引用密钥库数据库内部别名的新AES-256密钥有多么容易。 然后,该帖子继续介绍如何在给定密钥的情况下对消息进行加密和解密,但是还显示了如何在密钥库中获取对该密钥的引用。

// for clarity, ignoring exceptions and failures
InputStream keystoreStream = new FileInputStream(keystoreLocation);KeyStore keystore = KeyStore.getInstance("JCEKS");
keystore.load(keystoreStream, keystorePass.toCharArray());if (!keystore.containsAlias(alias)) {throw new RuntimeException("Alias for key not found");
}Key key = keystore.getKey(alias, keyPass.toCharArray());

参量

keystoreLocation :字符串–本地密钥库文件位置的位置 keypass :字符串–使用keytool创建或修改密钥库文件时使用的密码(请参见上文) alias :String –使用keytool创建新密钥时使用的别名(请参见上文)

结论

这篇文章展示了如何使用AES-256加密算法对基于字符串的消息进行加密和解密。 加密和解密这些消息的密钥保存在使用JDK提供的“ keytool”实用程序创建的JCEKS格式的KeyStore数据库中。 这篇文章中的示例应被视为加密/解密对称密钥(例如AES)的坚实起点。 加密消息(例如密钥旋转)时,这不应被视为唯一的防线。 密钥轮换是一种减轻数据泄露事件风险的方法。 如果入侵者获取数据并设法破解单个密钥,则多个文件中包含的数据应已使用多个密钥对数据进行加密,从而降低了总暴露损失的风险。

该博客文章中的所有示例都已简化为一个简单的工具,允许查看密钥库中的密钥,而JDK密钥工具不支持开箱即用的操作。 这篇文章中概述的步骤和主题的各个方面都可以在以下网址获得: https : //github.com/mike-ensor/aes-256-encryption-utility 。 注意:示例,示例代码和任何参考资料均由实施者自担风险,没有任何默示的保证或责任,您承担所有风险。

参考:来自Mike站点博客上的JCG合作伙伴 Mike Ensor 提供的Java和JCEKS的AES-256加密 。

翻译自: https://www.javacodegeeks.com/2014/02/aes-256-encryption-with-java-and-jceks.html

aes256加密java

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/344523.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【渝粤教育】电大中专Windows操作系统作业 题库

学习好Windows10应用这门课程,应该()。 A重视理论学习 B重视上机操作,多练多试 C只看不练 D可以随便学习一下 正确 正确答案:左边查询 学生答案:B 2在使用Windows时遇到困难,(&#…

高可用mysql笔记_MySQL笔记-高可用方案

MySQL笔记-高可用方案一、概述MYSQL高可用方案有多种,本次针对其中部分方案进行实践。包括主从,双主,myqlkeepalived, mysqlmycatkeepalived。纸上得来终觉浅,亲自实验一下。环境信息注意两台机器时间需要保持同步,网络…

【渝粤教育】电大中专办公设备使用与维护 (2)_1作业 题库

1以下哪个不是现代办公硬件需求的主要依赖()。 A扫描仪 B计算机 C办公桌 D打印机 错误 正确答案:左边查询 学生答案:B 2现代办公设备可分为计算机、通信()三大类。 A电子工具 B办公机械 C路由器 D碎纸机 错…

无服务器冷启动不是问题-这就是为什么(对于大多数应用程序)

从无服务器开始时,您很快就会学习/听到有关函数冷启动的信息(我相信无服务器云功能 API )。 首次调用云功能时或长时间不调用后会发生冷启动。 基本上,服务器(是的,有服务器!)需要一…

【渝粤教育】电大中专学前儿童健康教育作业 题库

1健康的定义是()年,世界卫生组织提出的。 A1945 B1948 C1955 D1958 错误 正确答案:左边查询 学生答案:A 2健康不仅仅是没有疾病或虚弱,而是包括身体、心理和()方面的完好状态。 A精神 B躯体 C社会 D道德 错误 正确答案&#xff1a…

python学习与数据挖掘_Python学习之数据挖掘(三)

Pandas基础处理Pandas是什么?为什么用?核心数据结构DataFramePanelSeries基本操作运算画图文件的读取与存储高级处理4.1Pandas介绍4.1.1 Pandas介绍 - 数据处理工具panel data analysispanel面板数据 - 计量经济学 三维数据4.1.2 为什么使用Pandas便捷…

【渝粤教育】电大中专学前儿童科学教育 (14)作业 题库

1学前儿童科学教育的学习重点是() A学前儿童科学教育的内涵 B学前儿童科学教育的概念 C科学的概念 D技术的概念 错误 正确答案:左边查询 学生答案:A 2学前儿童科学教育的学习难点是() A学前儿童科学教育的内涵 B学前儿童科学教育在儿童发展中的意义 C学前…

生成器作为(快速失败)状态机

这个想法是几周前在设计“ Generator”类时想到的,该类必须将输入发送给封装的Writer 。 实际上,它是Builder模式。 但是,规则有些复杂,用户必须以某种方式调用add...()方法,才能正确生成输出。 不用说,我…

【渝粤教育】电大中专市场营销管理20作业 题库

1.市场营销没有宏观市场营销和微观市场营销之分。该说法:( ) A.错误 B.正确 错误 正确答案:左边查询 学生答案:B 2.战略选择的陷阱有:盲目跟随、墨守成规、军备竞赛、多方出击、孤注一掷、本末倒置。该说法…

源码包编译安装python_Python3.7源码包编译安装-Go语言中文社区

环境:[rootlocalhost python3]# cat /etc/redhat-releaseCentOS Linux release 7.5.1804 (Core)[rootlocalhost python3]#1、下载Python方式一:方式二:进入https://www.python.org/ftp/python/ 这里存放着所有版本的Python源码。往下拉看到最…

【渝粤教育】电大中专建筑力学 (4)作业 题库

1.下列说法不正确的是()。 A.力偶在任何坐标轴上的投形恒为零 B.力可以平移到刚体内的任意一点 C.力系的合力在某一轴上的投形等于各分力在同一轴上投形的代数和 D.力使物体绕某一点转动的效应取决于力的大小和力作用线到该点的垂直距离 正确 正确答案&a…

java criteria and_criteria用法

Criteria Query通过面向对象化的设计,将数据查询条件封装为一个对象。简单来讲,Criteria Query可以看作是传统SQL的对象化表示,如:Java代码Criteria criteria session.createCriteria(User.class);criteria.add(Expression.eq(&q…

【渝粤教育】电大中专新媒体营销实务 (4)作业 题库

1.( )对新媒体的定义为:“以数字信息技术为基础,以互动传播为特点,具有创新形态的媒体。” A.新传媒产业联盟秘书长王斌 B.联合国教科文组织 C.华纳兄弟总裁施瓦茨威格 正确 正确答案:左边查询 学生答案&am…

服务网格:Istio和AWS App Mesh

本周在AWS re:Invent上的重大公告之一是AWS App Mesh 。 在谈论它之前,让我们先看一下网格到底是什么…… 什么是服务网格? 服务网格是微服务体系结构的基础结构层。 它处理服务之间的通信问题,使该通信更加可见(或“…

【渝粤教育】电大中专消费者心理学_1作业 题库

1.在西方,早期思想家也有论及消费时令和消费季节的朴素思想。该说法() A.错误 B.正确 正确 正确答案:左边查询 学生答案:A 2.体系凝构阶段大致自20世纪70年代延至20世纪末或21世纪初。该说法() …

java按键发出声音代码_怎么在java中给按钮添加声音?

可以加入GTM时间,代码如下:public class ShowCurrentTime {public static void main(String args[]){//Obtain the total milliseconds since midnight,Jan 1,1970long totalMillisecondsSystem.currentTimeMillis();//Obtain the total seconds since i…

Spring字段依赖注入示例

学习如何编写Spring Field Injection示例 。 字段注入是Spring框架 依赖注入的一种 。 在本教程中,我们将编写几个类,并看一看现场注入工程。 有关Spring依赖注入的更多信息: Spring Setter依赖注入示例 Spring构造函数依赖注入示例 Spri…

java8 新特性之流式数据处理_Java8新特性 - 集合流式编程 - 最终操作

2、数据源的获取2.1、数据源的简介数据源,顾名思义,既是流中的数据的来源。是集合的流式编程的第一步,将数据源中的数据读取到流中,进行处理。注意:将数据读取到流中进行处理的时候,与数据源中的数据没有关…

【渝粤教育】电大中专电大中专职业健康与安全考试考核试题作业 题库

试卷答案 1根据系统安全工程的观点,危险是指系统中存在导致发生不期望后果的可能性超过了( ) A极限 B人们的承受程度 C危险度 D安全系数 错误 正确答案:左边查询 学生答案:A 2对职工来说,安全是&#xff0…

java jdt_在JDT中使用Java 8 Lambda

java jdt旧 Curmudgeon 认识Smalltalk的Dude 在修改Eclipse Java开发工具 (JDT)项目正在开发的Java 8支持时,我一直在使用这种语言。 我承认我对Java 8中的lambda有点不满意。 当然,这来自于知道Smalltalk (和LISP…