本章主要讲述密码学在认证方面的应用。认证是验证用户身份或者数据完整性的过程。有三种类型的认证技术:消息摘要、数字签名以及证书。
消息摘要
消息摘要对于数据来讲是一种重要的指纹。消息摘要的目的就是防止数据被篡改。
从数据获取消息摘要的过程通常称作杂凑。利用消息摘要相对于直接与原始数据的拷贝进行比较的优点在于它的长度:不管数据的长度有多大,消息摘要的长度通常只有16或者20个字节长。消息摘要计算起来比较简单:利用消息摘要算法对数据进行处理即可得到消息摘要。
消息摘要的一个用途就是在FTP中进行文件的确认。大文件传送中有时会出现一些问题。如果服务器提供了该文件的消息摘要,你就可以在下载该文件后进行比较,以确保文件传送的正确性。
口令认证
消息摘要的一个常用的用途就是口令认证。由于消息摘要是单向转换得来的数据,因此由它不可能得到原始数据。我们可以只存储口令的杂凑值,这样就没有人能破译出存储的口令,因为没有任何方法可以直接破译消息摘要。
为了让攻击者获取了经杂凑处理的口令,也更难猜出口令,需要使用加盐的方法来存储口令,这样就可以使口令攻击者预先产生常用口令的消息摘要清单这一方法不可行。
消息认证码(MAC)
消息认证码是一种非常重要的消息摘要。它通常用于在不安全的网络,如Internet上鉴别传送的数据。通信的双方交换密钥,然后用这个密钥对数据进行验证。因为是通过密码学的方法利用共享密钥来保护消息摘要,所以MAC解决了如何在不安全的网络环境中传送消息摘要的问题。
基于密码学上的hash函数的MAC通常被称作HMAC(杂凑消息认证码)。还有其他类型的MAC,它们是基于分组密码的,但并不常用。
在Sun的JCE中有两种HMAC函数:一种是用MD5算法,另一种使用SHA-1算法。你可以用参数HmacMD5和HmacSHA1对它们进行调用。其他的提供者,如Bouncy Castle,甚至支持更多的算法。
数字签名
数字签名有点类似于用数字方式的物理签名,但它们又不完全相同。数字签名与单独的数据,如签字的合同或者电子邮件有关。物理签名也是为了完成相同的工作,但是物理签名却无法引用待签的文档。强迫进行物理签名比强迫进行数字签名容易得多:只需从另一个文档拷贝该签名即可。数字签名通常提供更高的安全度,因为它们与签名的文档相关,而且如果无法读取所使用的密钥,就很难伪造签名。
数字签名是一种重要的消息摘要,它是用自己的私钥进行处理的。你可以先将要签名的数字送给消息摘要算法,然后消息摘要和私钥送给签名算法。所得到的数据就是所要得到的数字签名,它是用私钥签名的。签名数据与原始数据一起传送,以此证明该数据是由持有私钥的人签署的。
为了验证签名,必须使用签名者的公钥,然后比较数据的消息摘要,如果相同,就可以知道该数据是用对应的私钥签名的,你也可以通过这个结果知道,数据自签名后没有被修改。
数字签名有两个主要用途:保持数据的完整性和同一性。
数字证书
数字证书是由第三方提供的一种确保该公钥是由其宣称者所拥有的一种方式。然而,证书不只可以发布给人,还可以发布给一些主体,如公司或者其他组织。
一般情况下,证书是由你的公钥和一些其他信息组成,这些信息和你的公钥是由第三方的私钥进行签名。通常,第三方称作CA(证书授权机构)。
两个最著名的CA是Verisign和Thawte(后者实际上是前者的子公司)。还有一些其他的CA公司,但它们只占据很少一部分CA市场。通过对你的公钥进行签名,CA可以保证这个公钥是由你所发布的。
证书链
证书主要是为了确保公钥正确性。还是可以对这一功能进行扩充,可以将多个证书链接起来组成一个证书链。证书链中的每个实体(除了最后一个实体之外)都是一个CA。证书链用于管理证书。通过建立子证书,就易于实现每个证书的功能。
证书撤销清单(CRL)
有时,需要在证书有效期之间取消该证书。证书撤销清单提供了这种功能。CRL中存放了由CA签署的已被撤销的证书的序列号。每个CA都有它自己的CRL可供下载。如果你想知道某个证书是否有效,可以检查一下CRL,看看有无该证书的序列号。如果没有的话,则该证书还没有被撤销。
公钥基础设施(PKI)
公钥基础设施是管理公钥密码的一个基本系统。正如我们所知道的,在配置甚至刚刚开始建立安全系统时,就涉及到很多的算法、协议和安全概念。PKI试图将大量的算法和标准集成进一个统一的系统中以提供安全服务。
PKI至少必须提供以下服务:
分享到:
相关推荐
Java学习笔记Java学习笔记Java学习笔记Java学习笔记Java学习笔记Java学习笔记Java学习笔记Java学习笔记Java学习笔记Java学习笔记Java学习笔记Java学习笔记Java学习笔记Java学习笔记Java学习笔记Java学习笔记Java学习...
这本"Java并发编程学习笔记"可能是作者在深入研究Java并发特性、工具和最佳实践过程中积累的心得体会。下面,我们将根据这个主题,探讨一些关键的Java并发编程知识点。 1. **线程与进程**:在多任务环境中,线程是...
Java是一种广泛使用的面向对象的编程语言,其设计目标是具有高度的可移植性,灵活性和安全性。本学习笔记主要涵盖了Java的基础知识,包括面向对象、集合、IO流、多线程、反射与动态代理以及Java 8的新特性等方面,...
3. **枚举**:枚举是Java中的一种特殊类,用于定义一组固定的常量,提高了代码的可读性和安全性。 4. **注解(Annotation)**:注解提供了一种元数据,用于向编译器或JVM提供关于代码的附加信息,例如用于代码生成...
Java是一种广泛使用的面向对象的编程语言,由Sun Microsystems(现为Oracle公司的一部分)于1995年发布。...Java学习笔记涵盖了这些核心知识点,通过深入学习和实践,你可以逐步掌握Java编程,并应用于实际项目开发中。
java学习笔记java学习笔记.zipjava学习笔记.zipjava学习笔记.zipjava学习笔记.zipjava学习笔记.zipjava学习笔记.zipjava学习笔记.zipjava学习笔记.zipjava学习笔记.zipjava学习笔记.zipjava学习笔记.zipjava学习笔记...
JAVA的面向对象编程学习笔记
【Java学习笔记Markdown版】是针对Java初学者和进阶者的一份详尽教程,以Markdown格式编写,便于阅读和整理。Markdown是一种轻量级的标记语言,它允许用户使用易读易写的纯文本格式编写文档,然后转换成结构化的HTML...
以下是Java学习笔记的摘要信息: 一、Java技术基础 * 1.1 编程语言:Java是一种面向对象的编程语言,具有跨平台、动态加载、多线程等特点。Java语言的设计目标是提供一种通用的、基于对象的、高度面向对象的编程...
笔记的第一部分是"Java入门第一季学习笔记",它可能包括Java的基础概念和语法。这部分可能会讲解如何安装Java开发工具包(JDK),创建第一个Java程序——经典的"Hello, World!",理解变量、数据类型、运算符、流程...
JAVA学习笔记是面向对象编程语言的学习笔记,涵盖了JAVA的基本概念、面向对象编程思想、类和对象的概念、实例变量和局部变量的区别、方法的定义和调用、类型转换、精度问题、移位问题、switch语句的使用等内容。...
Java是一种流行的面向对象编程(OOP)语言,其基本概念和特性对于初学者来说需要系统地学习和理解。本知识点的标题为“Java学习笔记(必看经典)”,意味着所整理的内容是针对Java初学者的一系列核心概念和原理的总结。 ...
Java面向对象编程学习笔记.pdf提供了Java面向对象编程的基础知识,包括类和对象、继承、多态性、封装、抽象、接口和异常处理等内容。学习这些知识点可以帮助开发者更好地理解和应用Java面向对象编程。
《java并发编程实战》读书笔记-第2章-线程安全性,脑图形式,使用xmind8制作 包括引言、线程安全性定义、原子性、加锁机制、使用锁保护状态、活跃性与性能等内容
Java是一种广泛使用的面向对象的编程语言,以其跨平台、健壮性和安全性著称。这份《java学习》笔记包含了多个核心主题,旨在帮助初学者和有经验的开发者深入理解和掌握Java技术。 1. **正则表达式(正则.md)**: ...
泛型编程提高了Java代码的复用性和类型安全性。容器类如List、Set和Map为处理数据集合提供了丰富的方法。 I/O系统涉及到字节流和字符流的处理,文件操作,以及对象序列化等。并发编程部分涵盖了线程的概念、并发...
### 韩顺平编写的Java学习笔记概览 #### Java平台分类与运行机制 - **J2SE(Java 2 Platform, Standard Edition)**: 标准版Java开发平台,适用于桌面应用程序开发。 - **J2EE(Java 2 Platform, Enterprise ...
Java并发编程是指在Java语言中编写多线程和多任务执行的程序,以便更高效地利用计算机的多核处理器资源。并发编程是Java高级编程技能中的重要组成部分,尤其是在需要处理大量数据、提供快速响应、实现高吞吐量和高可...