此类位于 javax.crypto.spec 包下。声明如下:

public class DESKeySpec extends Object implements KeySpec
此类指定一个 DES 密钥。
KeySpec是一个接口,用来组成加密密钥的密钥内容的(透明)规范。如果密钥存储在硬件设备上,则其规范可以包含有助于标识该设备上的密钥的信息。

用特定于算法的方法或独立于算法的编码格式(例如,ASN.1)可以指定密钥。例如,DSA 专用密钥可以由其组件 xpqg 指定(请参见 DSAPrivateKeySpec),或使用其 DER 编码指定(请参见 PKCS8EncodedKeySpec)。

此接口不包含任何方法或常量。它仅用于将所有密钥规范分组,并为其提供类型安全。所有密钥规范都必须实现此接口。

1、字段:DES_KEY_LEN 值为8, 定义以字节为单位的 DES 密钥长度的常量。
2、构造方法:
①public DESKeySpec(byte[] key) throws InvalidKeyException
创建一个 DESKeySpec 对象,使用 key 中的前 8 个字节作为 DES 密钥的密钥内容。

组成 DES 密钥的字节在 key[0]key[7] 范围内(包含两者)

   参数:
key - 具有 DES 密钥内容的缓冲区。复制该缓冲区的前 8 个字节来防止后续修改。 抛出异常:如果给定的密钥内容短于 8 个字节。会抛出InvalidKeyException异常。

②public DESKeySpec(byte[] key,int offset) throws InvalidKeyException

创建一个 DESKeySpec 对象,使用 key 中始于且包含 offset 的前 8 个字节作为 DES-EDE 密钥的密钥内容。

组成 DES 密钥的字节在 key[offset]key[offset+7] 范围内(包含两者)。

参数:key - 具有 DES 密钥内容的缓冲区。复制该缓冲区始于且包含 offset 的前 8 个字节来防止后续修改。 offset - key 中的偏移量,DES 密钥内容从此处开始。

抛出异常:同上

3、方法详细:

①public byte[] getKey()    返回 DES 密钥内容。每一次调用此方法都返回一个新数组。

②public static boolean isParityAdjusted(byte[] key, int offset) throws InvalidKeyException

确定给定的始于且包含 offset 的 DES 密钥内容是否是奇偶校验的 (parity-adjusted)。如果给定的 DES 密钥内容是奇偶校验的,则返回 true,否则返回 false。

③public static boolean isWeak(byte[] key,int offset) throws InvalidKeyException    确定给定的 DES 密钥内容是否是全弱或者半弱的。

测试示例如下:

package com.home;

import javax.crypto.spec.DESKeySpec;

public class TestDESKeySpec {
private DESKeySpec keySpec1;// DESKeySpec实例1
private DESKeySpec keySpec2;// DESKeySpec实例2
private byte[] DESkey;// 设置密钥 public TestDESKeySpec() {
printDESKEYLEN();
try {
this.DESkey = "abcdefghijklmn".getBytes();
keySpec1 = new DESKeySpec(DESkey);
keySpec2 = new DESKeySpec(DESkey, 3);
printKey(keySpec1);
printKey(keySpec2);
// 确定给定的 DES密钥内容是否是奇偶校验的
System.out.println(DESKeySpec.isParityAdjusted(DESkey, 3));
// 确定给定的 DES密钥内容是否是全弱或者半弱的
System.out.println(DESKeySpec.isWeak(DESkey, 3));
} catch (Exception e) {
} } public static void main(String[] args) {
new TestDESKeySpec();
} /**
* 打印以字节为单位的 DES密钥长度的常量的值
*/
private void printDESKEYLEN() {
System.out.println("以字节为单位的 DES密钥长度的常量:" + DESKeySpec.DES_KEY_LEN); } /**
* 打印keySpec的key
*
* @param keySpec
*/
private void printKey(DESKeySpec keySpec) {
String keyStr = new String(keySpec.getKey());
System.out.println(keySpec + "的key:" + keyStr);
}
}

Java中DESKeySpec类的更多相关文章

  1. 基础知识(05) -- Java中的类

    Java中的类 1.类的概念 2.类中的封装 3.对象的三大特征 4.对象状态 5.类与类之间的关系 ------------------------------------------------- ...

  2. JAVA中的类和接口

    1.类: 类是具有相同属性和方法的一组对象的集合,它为属于该类的所有对象提供了统一的抽象描述,其内部包括属性和方法两个主要部分.在面向对象的编程语言中,类是一个独立的程序单位,它应该有一个类名并包括属 ...

  3. java中Color类的简单总结

    java中Color类的简单总结 1.颜色的常识 任何颜色都是由三原色组成(RGB),JAVA中支持224为彩色,即红绿蓝分量取值 介于0-255之间(8位表示) 2.Color类中的常量 publi ...

  4. Java中String类的方法及说明

    String : 字符串类型 一.      String sc_sub = new String(c,3,2);    //      String sb_copy = new String(sb) ...

  5. java中的类和对象

    Java中的类是一个模板,它用于描述一类对象的行为和状态. 对象则是类中的一个实例,对象有状态(属性)和行为(方法).例如一条狗就是一个对象,他的状态就是他的颜色,名字,品种:他的行为就是叫,摇尾巴, ...

  6. java中String类学习

    java中String类的相关操作如下: (1)初始化:例如,String s = “abc”; (2)length:返回字符串的长度. (3)charAT:字符操作,按照索引值获得字符串中的指定字符 ...

  7. 【JAVA零基础入门系列】Day11 Java中的类和对象

    今天要说的是Java中两个非常重要的概念--类和对象. 什么是类,什么又是对象呢?类是对特定集合的概括描述,比如,人,这个类,外观特征上,有名字,有年龄,能说话,能吃饭等等,这是我们作为人类的相同特征 ...

  8. 在java中String类为什么要设计成final

    在java中String类为什么要设计成final? - 胖胖的回答 - 知乎 https://www.zhihu.com/question/31345592/answer/114126087

  9. 关于Java中基类构造器的调用问题

    在<Java编程思想>第7章复用类中有这样一段话,值得深思.当子类继承了父类时,就涉及到了基类和导出类(子类)这两个类.从外部来看,导出类就像是一个与基类具有相同接口的新类,或许还会有一些 ...

随机推荐

  1. mysqld.cc启动分析及运行过程(题目取大了,不好意思)

    mysql源文件的压缩文件mysql-5.7.12.tar.gz有48.2Mb,这么大个家伙. 以前学c语言什么的,觉得尼玛个臭c可以干嘛呀,敢看了源文件我彻底震精了,光是一个THD类的说明就占了30 ...

  2. ReentrantReadWriteLock锁例子

    锁所提供的最重要的改进之一就是ReadWriteLock接口和唯一 一个实现它的ReentrantReadWriteLock类.这个类提供两把锁,一把用于读操作和一把用于写操作.同时可以有多个线程执行 ...

  3. Android——监听事件OnLongClickListener

    .xml <Button android:layout_width="wrap_content" android:layout_height="wrap_conte ...

  4. u-boot可ping通PC,PC不可ping通u-boot

    http://blog.csdn.net/ce123_zhouwei/article/details/7339134 开发板运行U-Boot,在终端下使用Ping命令是能Ping通PC机,但PC机Pi ...

  5. Windows Server 2008组策略安全实践(同样适用于域控制)

    Windows Server 2008系统的安全功能非法强大,而它的强大之处不仅仅是新增加了一些安全功能,而且还表现在一些不起眼的传统功能上.对Windows Server 2008系统的组策略功能进 ...

  6. JEECG常见问题大全征集

    大家还有什么问题.请跟帖,谢谢支持. .  JEECG常见问题大全征集 1. jeecg没有数据库脚本问题   jeecg不须要数据库脚本,在数据库创建好数据库.项目配置好数据源链接.会自己主动建表. ...

  7. 批量改名的多种方法stu_3_finished.jpg 去掉finished,stu_{1..20}_finished.jpg

    方法一:rename修改文件名 rename "finished" "" *.jpg [root@ob1 scripts]# rename "fini ...

  8. jquery easy ui 简单字段选择搜索实现

    code <!DOCTYPE html><html><head> <meta charset="UTF-8"> <title& ...

  9. 关于Cocos2d-x中GameController的定义

    GameController类是继承自Scheduler(有计时功能)或者Ref(可自动释放)的用户自己定义的一个控制器 如果一个场景有多个层的话,要用GameController,一个GameCon ...

  10. TensorFlow基础笔记(13) Mobilenet训练测试mnist数据

    主要是四个文件 mnist_train.py #coding: utf-8 import os import tensorflow as tf from tensorflow.examples.tut ...