java中常用的加密算法有:1.BASE64算法,二进制数据;2.MD5算法,散列函数;3.SHA算法,消息摘要算法;4.RSA算法,用于加密和数字签名的算法;5.DES算法,对称密码体制加密算法;6.PBE算法,基于口令的加密算法;7.DH算法,密钥交换算法;8.DSA算法,数字签名算法;9.ECC算法,椭圆加密算法;
java中常用的加密算法有以下几种
BASE64算法
BASE64算法是一种基于64个可打印字符来表示二进制数据的表示方法,Base64算法可以将任意序列的8位字节描述为一种不易被人直接识别的形式,其复杂程度小,但效率高。
MD5算法
MD5算法是计算机安全领域广泛使用的一种散列函数,用以提供消息的完整性保护,MD5是以512位分组来处理输入的信息,且每一分组又被划分为16个32位子分组,经过了一系列的处理后,算法的输出由四个32位分组组成,将这四个32位分组级联后将生成—个128位散列值。
SHA算法
SHA算法是一种消息摘要算法,SHA1主要适用于数字签名标准里面定义的数字签名算法。
RSA算法
RSA算法是一种使用不同的加密密钥与解密密钥,是由已知加密密钥推导出解密密钥在计算上是不可行的密码体制,其原理是根据数论,寻求两个大素数比较简单,而将它们的乘积进行因式分解却极其困难,因此可以将乘积公开作为加密密钥。
DES算法
DES算法是一种对称密码体制加密算法,为密码体制中的对称密码体制,其 明文按64位进行分组,密钥长64位,密钥是以56位参与DES运算,且第8、16、24、32、40、48、56、64位是校验位,分组后的明文组和56位的密钥按位替代或交换的方法形成密文组的加密方法。
PBE算法
PBE算法是一种基于口令的加密算法,其特点在于口令是由用户自己掌握的,采用随机数杂凑多重加密等方法保证数据的安全性,且PBE算法没有密钥的概念,密钥在其它对称加密算法中是经过算法计算得出来的,PBE算法则是使用口令替代了密钥。
DH算法
DH算法是一种密钥交换算法,可以让双方在完全没有对方任何预先信息的条件下通过不安全信道建立起一个密钥,且密钥可以在后续的通讯中作为对称密钥来加密通讯内容。
DSA算法
DSA算法是一种数字签名算法,是一种公开密钥算法,其不能用作加密,只用作数字签名,DSA算法使用公开密钥,可以为接受者验证数据的完整性和数据发送者的身份。
ECC算法
ECC算法是一种椭圆加密算法,可以通过较短的密钥达到相同的安全程度,常用于用于加解密、签名验签,也可以与DH结合使用,用于密钥磋商。