`

javax.crypto.Cipher类提供加密和解密功能,该类是JCE框架的核心

    博客分类:
  • pki
阅读更多

javax.crypto.Cipher类提供加密和解密功能,该类是JCE框架的核心。

一,与所有的引擎类一样,可以通过调用Cipher类中的getInstance静态工厂方法得到Cipher对象。

public static Cipher getInstance(String transformation);

public static Cipher getInstance(String transformation,String provider);

参数transformation是一个字符串,它描述了由指定输入产生输出所进行的操作或操作集合。

参数transformation总是包含密码学算法名称,比如DES,也可以在后面包含模式和填充方式。

参数transformation可以是下列两种形式之一:

“algorithm/mode/padding”

“algorithm”

例如下面的例子就是有效的transformation形式:

"DES/CBC/PKCS5Padding"

"DES"

如 果没有指定模式或填充方式,就使用特定提供者指定的默认模式或默认填充方式。例如,SunJCE提供者使用ECB作为DES、DES-EDE和 Blowfish等Cipher的默认模式,并使用PKCS5Padding作为它们默认的填充方案。这意味着在SunJCE提供者中,下列形式的声明是 等价的:Cipher c1=Cipher.getInstance("DES/ECB/PKCS5Padding");

     Cipher c1=Cipher.getInstance("DES");

当 以流加密方式请求以块划分的cipher时,可以在模式名后面跟上一次运算需要操作的bit数目,例如采用"DES/CFB8/NoPadding"和 "DES/OFB32/PKCS5Padding"形式的transformation参数。如果没有指定数目,则使用提供者指定的默认值(例如 SunJCE提供者使用的默认值是64bit)。

getInstance工厂方法返回的对象没有进行初始化,因此在使用前必须进行初始化。

通过getInstance得到的Cipher对象必须使用下列四个模式之一进行初始化,这四个模式在Cipher类中被定义为final integer常数,我们可以使用符号名来引用这些模式:

ENCRYPT_MODE,加密数据

DECRYPT_MODE,解密数据

WRAP_MODE,将一个Key封装成字节,可以用来进行安全传输

UNWRAP_MODE,将前述已封装的密钥解开成java.security.Key对象

每个Cipher初始化方法使用一个模式参数opmod,并用此模式初始化Cipher对象。此外还有其他参数,包括密钥key、包含密钥的证书certificate、算法参数params和随机源random。

我们可以调用以下的init方法之一来初始化Cipher对象:

public void init(int opmod,Key key);

public void init(int opmod,Certificate certificate);

public void init(int opmod,Key key,SecureRandom random);

public void init(int opmod,Certificate certificate,SecureRandom random);

public void init(int opmod,Key key,AlgorithmParameterSpec params);

public void init(int opmod,Key key,AlgorithmParameterSpec params,SecureRandom random);

public void init(int opmod,Key key,AlgorithmParameters params);

public void init(int opmod,Key key,AlgorithmParameters params,SecureRandom random);

必须指出的是,加密和解密必须使用相同的参数。当Cipher对象被初始化时,它将失去以前得到的所有状态。即,初始化Cipher对象与新建一个Cipher实例然后将它初始化是等价的。

二,可以调用以下的doFinal()方法之一完成单步的加密或解密数据:

public byte[] doFinal(byte[] input);

public byte[] doFinal(byte[] input,int inputOffset,int inputLen);

public int doFinal(byte[] input,int inputOffset,int inputLen,byte[] output);

public int doFinal(byte[] input,int inputOffset,int inputLen,byte[] output,int outputOffset);

在多步加密或解密数据时,首先需要一次或多次调用update方法,用以提供加密或解密的所有数据:

public byte[] update(byte[] input);

public byte[] update(byte[] input,int inputOffset,int inputLen);

public int update(byte[] input,int inputOffset,int inputLen,byte[] output);

public int update(byte[] input,int inputOffset,int inputLen,byte[] output,int outputOffset);

如果还有输入数据,多步操作可以使用前面提到的doFinal方法之一结束。如果没有数据,多步操作可以使用下面的doFinal方法之一结束:

public byte[] doFinal();

public int doFinal(byte[] output,int outputOffset);

如果在transformation参数部分指定了padding或unpadding方式,则所有的doFinal方法都要注意所用的padding或unpadding方式。

调用doFinal方法将会重置Cipher对象到使用init进行初始化时的状态,就是说,Cipher对象被重置,使得可以进行更多数据的加密或解密,至于这两种模式,可以在调用init时进行指定。

三,包裹wrap密钥必须先使用WRAP_MODE初始化Cipher对象,然后调用以下方法:

public final byte[] wrap(Key key);

如果将调用wrap方法的结果(wrap后的密钥字节)提供给解包裹unwrap的人使用,必须给接收者发送以下额外信息:

(1)密钥算法名称:

      密钥算法名称可以调用Key接口提供的getAlgorithm方法得到:

      public String getAlgorithm();

(2)被包裹密钥的类型(Cipher.SECRET_KEY,Cipher.PRIVATE_KEY,Cipher.PUBLIC_KEY)

sourcelink: http://bbs.sdu.edu.cn/pc/pccon.php?id=1292&nid=41716&order=&tid=


为了对调用wrap方法返回的字节进行解包,必须先使用UNWRAP_MODE模式初始化Cipher对象,然后调用以下方法 :

public final Key unwrap(byte[] wrappedKey,String wrappedKeyAlgorithm,int wrappedKeyType));

其 中,参数wrappedKey是调用wrap方法返回的字节,参数wrappedKeyAlgorithm是用来包裹密钥的算法,参数 wrappedKeyType是被包裹密钥的类型,该类型必须是Cipher.SECRET_KEY,Cipher.PRIVATE_KEY, Cipher.PUBLIC_KEY三者之一。

四,SunJCE提供者实现的cipher算法使用如下参数:

(1)采用CBC、CFB、OFB、PCBC模式的DES、DES-EDE和Blowfish算法。,它们使用初始化向量IV作为参数。可以使用javax.crypto.spec.IvParameterSpec类并使用给定的IV参数来初始化Cipher对象。

(2)PBEWithMD5AndDES使用的参数是一个由盐值和迭代次数组成的参数集合。可以使用javax.crypto.spec.PBEParameterSpec类并利用给定盐值和迭代次数来初始化Cipher对象。

注意:如果使用SealedObject类,就不必为解密运算参数的传递和保存担心。这个类在加密对象内容中附带了密封和加密的参数,可以使用相同的参数对其进行解封和解密。

Cipher 中的某些update和doFinal方法允许调用者指定加密或解密数据的输出缓存。此时,保证指定的缓存足够大以容纳加密或解密运算的结果是非常重要 的,可以使用Cipher的以下方法来决定输出缓存应该有多大:public int getOutputSize(int inputLen)

 

本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/wuwenlong527/archive/2008/01/11/2037931.aspx

分享到:
评论

相关推荐

    jce(Java加密扩展)

    1、javax.crypto.Cipher 类提供加密和解密的功能,它构成了 Java Cryptography Extension (JCE) —— Java 加密扩展框架的核心。这些都是 Java JDK 原生的 API,不是第三方的。 2、Cipher 的 getInstance(String ...

    bcprov加密库

    at javax.crypto.Cipher.getInstance(Cipher.java:656) at javax.crypto.Cipher.getInstance(Cipher.java:595) ... 12 more Caused by: java.util.jar.JarException: file:/opt/code/signal-Server-master/target...

    java对文件进行加密和解密操作

    Java中使用`javax.crypto.Cipher`类实现AES加密解密,通过`SecretKeySpec`创建密钥。 4. **非对称加密** - **RSA**:非对称加密的经典算法,安全性高,但速度相对较慢。Java通过`java.security.KeyPairGenerator`...

    Java 公钥和私钥加密解密代码

    5. Cipher:负责加密和解密操作的类。 以下是一个简单的Java代码示例,演示了如何生成公钥和私钥对,并使用它们进行加密和解密: ```java import java.security.KeyPair; import java.security.KeyPairGenerator; ...

    DES.JAVA.rar_DES JAVA_des

    2. `javax.crypto.Cipher` - 提供加密和解密操作的接口。 3. `javax.crypto.SecretKeyFactory` - 用于生成和处理对称密钥的工厂类。 4. `javax.crypto.spec.DESKeySpec` - DES密钥规范,用于创建DES密钥。 下面是一...

    java 实现加密解密

    - Cipher类是实际执行加密和解密操作的核心,它实现了各种加密算法。例如,使用AES加密可以如下: ```java Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5Padding"); SecretKeySpec keySpec = new ...

    jsencrypt.min.js通过JSEncrypt分段加密解密

    在本文中,我们将深入探讨如何使用`JSEncrypt`库进行分段加密和解密,以及相关的知识点。 **RSA加密原理** RSA(Rivest-Shamir-Adleman)是一种非对称加密算法,它基于两个密钥:公钥和私钥。公钥可以公开,任何人...

    java加密解密工具

    1. Cipher:这是核心的加密/解密类,用于执行实际的加密和解密操作。它需要一个密钥和一个特定的算法。 2. KeyGenerator:用于生成密钥,根据指定的算法生成随机密钥。 3. 密钥类型:包括对称密钥(如AES)、非...

    用java实现“加密解密”

    在Java中,我们可以使用`javax.crypto`包下的类和接口来实现加密和解密操作。 1. **AES加密**:AES是一种块密码,处理单元为128位。在Java中,我们可以通过`Cipher`类和`SecretKeySpec`类来实现AES的加密和解密。...

    Cry-DES.rar_DES JAVA_des_encryption_java 加密解密_java des

    3. 初始化Cipher对象:Cipher是Java中用于加密和解密的核心类。根据操作模式(如ECB、CBC等)和填充方式,初始化Cipher对象。 ```java Cipher cipher = Cipher.getInstance("DES/ECB/PKCS5Padding"); ``` 4. 加密...

    JAVA数据加密解密的实例+

    首先,Java提供了Java Cryptography Extension (JCE)框架,它是一组用于加密、解密、数字签名和密钥协议的API。JCE支持多种加密算法,如AES(高级加密标准)、DES(数据加密标准)、RSA(公钥加密算法)等。 1. **...

    JAVA实现AES加密解密工具类

    AES加密解密工具类是开发人员在处理敏感信息时常用的实用工具,它可以简化加密和解密过程。本篇文章将深入探讨如何在Java中实现AES加密解密,并介绍相关的关键知识点。 首先,我们需要理解AES加密的基本原理。AES是...

    JAVA数据加密解密的实例+Java源码

    在Java编程语言中,数据加密和解密是信息安全领域中的重要技术,用于保护敏感信息,防止未经授权的访问或窃取。本实例将介绍如何在Java中实现数据的加解密,提供相关的源代码示例。 Java提供了丰富的加密库,如Java...

    AES实现前端JS和后端java加密解密

    使用Java的`javax.crypto.Cipher`类进行实际的加密和解密操作。 3. **加密方法**:在AESUtil中,定义一个`encrypt()`方法,接收明文、密钥和IV作为输入,然后使用`Cipher.init()`初始化加密操作,再调用`Cipher....

    AES加解密算法基于JCEAPI实现

    1. `javax.crypto.Cipher`:这是核心加密类,用于实现加密和解密操作。通过调用`Cipher.getInstance()`方法,我们可以获取到一个特定算法的实例,如"AES/ECB/PKCS5Padding",这个字符串定义了算法模式和填充方式。 ...

    java使用AES加密/解密文件

    本教程将详细讲解如何在Java中使用AES加密和解密文件,以确保数据的安全性。 AES全称为Advanced Encryption Standard,是一种对称加密算法,它在信息安全领域中被广泛应用,因为其速度快、效率高且安全性强。Java...

    DES加密解密Java工具

    DESEncrypt.java文件很可能是包含一个Java工具类,用于实现DES的加密和解密功能。下面将详细讲解如何使用Java进行DES操作。 1. 导入必要的库: 首先,在Java代码中需要导入以下JCE库中的类: ```java import ...

    c++ 加密, java解密 互通,下载直接引用

    在C++和Java中,我们可以使用相同的AES算法来确保加密和解密的一致性。 在C++中,可以使用如 OpenSSL 库来实现AES加密。OpenSSL提供了丰富的加密和哈希函数,包括AES。我们需要选择合适的模式(如ECB、CBC、CFB等)...

Global site tag (gtag.js) - Google Analytics