java security用法_Java加密体系(一)java.security包

一、JCA/ JCE

JCA(Java Cryptography Architecture) 是Java体系结构,提供了基本Java加密框架,比如证书、数字签名、消息摘要、秘钥对生成器等,在java.security包中实现。

JCE(Java Cryptography Extension)是JCA的扩展,主要负责提供DES、AES、RSA、DSA这样的加密算法,因为加密算法是会不断进步的,会有新的算法诞生,所以整个安全体系结构的可扩展性必须要得到保证。

JCE包因为其加密算法的安全限制,受美国出口限制,我们平时使用的是oracle提供的“阉割版”,比如默认不允许256位密钥的AES,我们通过oracle官网,可以下载“完整版”。

下面是“完整版的加密扩展包”

http://www.oracle.com/technetwork/java/javase/downloads/jce8-download-2133166.html

解压缩以后是这个样子:

548ec3b91d20

完整版加密扩展包.png

根据readme中的提示,放在/lib/security包中就可以啦

548ec3b91d20

image.png

JCE并不是只有oracle提供的,有多家厂商可以提供JCE的扩展包,在我们jdk的安装目录下的java.security文件中可以看到,支持的服务提供者Provider。

548ec3b91d20

Provider

JCA的实现是在java.security包下,这个包只能实现消息摘要算法,其他都要依赖JCE扩展包,在javax.crypto包中实现,也可以添加自己的provider,根据上图的格式继续填写第11个即可。使用Security.addProvider("xxx")可以完成Provider的添加,使用insertProviderAt("xxx", position)可以在指定位置完成添加,这里涉及到一个优先级的概念,如上图Provider所示,数字越小优先级越高。

借用oracle官方的一个例子,如图priv

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
除了jar之外,导致java.security.InvalidKeyException: Illegal key size异常的其他原因可能括以下几点: 1. 未正确安装或配置Java JRE或JDK:在某些情况下,如果Java环境未正确安装或配置,可能导致加密算法无法正常运行,从而引发此异常。此时,需要重新安装或配置Java环境。 2. Java Unlimited Strength Jurisdiction Policy文件缺失或配置问题:某些加密算法需要Java Unlimited Strength Jurisdiction Policy文件的支持才能正常工作。如果缺少该文件,或者文件未正确配置,就会导致Illegal key size异常。解决办法是下载并正确配置Java Unlimited Strength Jurisdiction Policy文件。 3. Java加密算法策略限制:某些情况下,默认的Java加密算法策略可能对加密密钥的长度有限制,当使用的密钥长度超出限制时,就会发生Illegal key size异常。解决办法是通过手动修改Java加密算法策略文件,将密钥长度限制调高。 4. 使用的加密算法不支持所提供的密钥长度:有些加密算法只支持特定长度的密钥。如果使用的加密算法不支持所提供的密钥长度,就会触发Illegal key size异常。解决方法是选择合适长度的密钥,或者尝试使用其他支持所需密钥长度的加密算法。 总结起来,导致java.security.InvalidKeyException: Illegal key size异常的除了jar之外的其他原因可能是Java环境未正确安装或配置、缺少Java Unlimited Strength Jurisdiction Policy文件、加密算法策略限制或使用不支持所提供的密钥长度的加密算法。需要检查和解决这些问题才能解决异常。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值