en_pkcs#8
cnpkcs10v1_7(认证请求语法标准)
组织:PKI 论坛()PKCS/PKIX 中文翻译计划论坛电子邮件译者:sql2000 (付少庆) ()版权:本中文翻译文档版权归PKI论坛的注册用户所共有。
可以用于非商业用途自由转载,但必须保留本文档的翻译及版权信息。
如用于商业目的,所得利润需用于PKI 论坛的发展。
更改记录* 修改类型分为C- 产生一- 附加的M- 修正D- 划除PKCS#10 认证请求语法标准(PKCS#10 : Certification Request Syntax Standard)RSA 实验室2000 年 5 月 26*目录:1.绪论........................................................................................................ 错误!未定义书签。
2.定义与符号............................................................................................ 错误!未定义书签。
定义................................................................................................... 错误!未定义书签。
符号................................................................................................... 错误!未定义书签。
3.概述..................................................................................................... 错误!未定义书签。
使用PKCS11标准开发跨硬件加密功能
第9卷第3期2006年7月西安文理学院学报:自然科学版Journal of Xi an University of Arts &Science(Nat Sci Ed)Vol.9 No.3Jul.2006文章编号:1008-5564(2006)03-0101-04收稿日期:2005-05-08基金项目:国家高技术研究发展 863 计划项目(2004AA 142151);中国科学院知识创新工程方向性项目(K GCX2-106).作者简介:葛澎(1968 ),男,陕西西安人,海军驻西安导弹设备军事代表处中校,硕士.使用PKCS11标准开发跨硬件加密功能葛 澎1,王 磊2,李向军3(1 海军驻西安导弹设备军事代表处,陕西西安710061;2 北京电信科学研究院数据通信研究所,北京100083;3 西安文理学院计算机科学系,陕西西安710065)摘 要:Cry ptoKi 接口是RSA 公司提出的PKCS #11标准中规定的标准加解密接口.它提供了一套独立于加密设备和操作系统的密码服务开发界面.首先简要介绍了通用Cry poK i 模型,随后分析了其逻辑结构和主要接口,并提供了一个开发实例用以说明作为一个密码部件接口,Cr yptoK i 为计算机或通信系统的安全提供了加解密基础.关键词:PKCS #11;Cr ypoK i;加密中图分类号:T P393.08 文献标识码:A为了能在信息安全中广泛应用密码功能,必需设置一种严格的彼此协作的商业标准规范.为达到目的,RSA 实验室提出了PKCS 规范(公共密钥加密标准,Public -Key Cryptography Standards),其中PKCS #11规范(Cryptog raphic Token Interface Standard,密码令牌标准)为开发人员提供了一套通用的跨操作系统和加密引擎的开发界面.PKCS #11标准为密码设备规定了一种程序设计接口,该接口称做CryptoKi [1](cryptographic token interface,密码令牌接口).CryptoKi 接口提供称为密码令牌的一种通用的加密设备逻辑视图及应用程序,从而实现了应用与密码设备具体细节相独立的目标.应用程序在转换成不同的加密设备接口或在不同环境下运行时不需进行调整,保证了应用程序良好的通用性和硬件兼容性.1 通用CryptoK i 接口模型CryptoKi 是一种应用程序与各种密码设备(基于智能卡、PCM CIA 卡以及智能软盘)间的一种接口.该接口提供与设备细节无关的密码令牌给应用程序使用.CryptoKi 的通用模型如图1所示.模型从一个或多个必须执行某些密码操作的应用程序开始,以一个或多个密码设备结束(在密码设备上执行某些或全部操作).一个用户可涉及也可不涉及一个程序.CryptoKi 为密码设备提供了一个接口,这些设备通过大量的槽在系统中运行.每个对应于一个物理阅读器或设备接口的槽可包含一个令牌.当密码设备与相应的阅读器连接时,一个令牌就存在于该槽中.多个槽可能共享一个阅读器.系统通常有相当多的槽,应用程序能连接到全部槽或某个指定槽的令牌上.密码设备可以按照指定的命令集执行某些密码操作,这些命令通常要经过标准设备驱动程序,例如PCM CIA 卡服务程序或槽服务程序.CryptoKi 隐藏了这些细节,使得每个密码设备具有相同的逻辑结构,而不关心其具体技术实现.因此,应用程序不必直接与设备驱动器接口通讯,甚至不必知道使用的是哪些设备.图1 通用CryptoKi 模型CryptoKi 的令牌逻辑视图是一个能存储对象和能执行密码函数的设备.Cry ptoKi 定义如下三个对象:数据、证书和密钥.数据对象由应用程序定义.令牌的逻辑视图如图2所示.对象可以根据它们的使用期限和可见度分为令牌对象和会话对象.令牌对象能被所有应用程序查看,即使在会话关闭或从槽中拔出令牌后,仍能保存在令牌上.会话对象则是暂时的,当会话关闭时,该会话产生的所有会话对象就会自动被破坏.此外,只有产生会话对象的应用程序能够查看它们.对象可以根据访问需求分为公共对象和私有对象.应用程序在查看公共对象时不需要存入令牌,然而如果要观察私有对象,用户必须通过PIN 或其它方式取得令牌授权.令牌能建立、破坏、寻找和搜寻对象,还可以执行带有对象的密码函数.图2 对象的层次结构CryptoKi 支持两种令牌用户类型:安全官员(SO)和普通用户.SO 的作用是初始化一个令牌,操作某些公共对象,设置普通用户的PIN 或通过其他方式确定普通用户的授权.普通用户只有在SO 设置普通用户的PIN 以后才能注册.然而只有普通用户才能访问令牌上的私有对象,当然首先普通用户需要得到授权.某些令牌可能不论是否涉及私有对象,在执行令牌上的加解密功能之前都需要用户得到授权.2 CryptoKi 接口概览及开发实例CryptoKi API 主要包含通用函数、槽和令牌管理函数、对象管理函数及加解密函数等.以下是一个简单的应用实例,它体现了Cryptoki 使用的一般流程.#define PL AIN T EXTBU F SZ 200#define CIPHERT EXTBU F SZ 256CKU L ONG firstPieceL en,secondPieceLen;CKSESSION HAN DLE hSessio n;CKOBJECT HA NDL E hK ey ;CKM ECHAN ISM mechanism ={CK M DES CBC PAD,iv,sizeof(iv)};CKBY T E data[PL AIN T EXT BU F SZ],encryptedData[CIPHERT EXT BU F SZ],iv[8];;CKU L ONG ulEncryptedData1Len,ulEncryptedData2L en,ulEncry ptedData3L en;CK 102西安文理学院学报:自然科学版第9卷firstPieceL en =90;secondPieceL en =PL AI NT EXTBU F SZ-firstPieceL en;rv =C_Encr yptI nit(hSession,&mechanism,hK ey);if (rv ==CK R OK ){/*Encrypt first piece */ulEncryptedData1Len =sizeof(encr yptedData);rv =C EncryptU pdate(hSession,&data[0],firstPieceL en,&encryptedData[0],&ulEncryptedData1Len);if (rv !=CKR OK ){/*错误处理*/}/*Encrypt second piece */ulEncryptedData2Len =sizeof(encr yptedData)-ulEncryptedData1Len;rv =C EncryptU pdate (hSession,&data[first PieceLen],secondPieceLen,&encryptedData[ulEncr yptedData1L en],&ulEncr yptedData2L en);if (rv !=CKROK ){/*错误处理*/}/*Get last little encr ypted bit */ulEncryptedData3Len =sizeof(encr yptedData)-ulEncryptedData1Len-ulEncryptedData2Len;rv =C EncryptFinal(hSession,&encry ptedData[ulEncryptedData1L en+ulEncryptedData2Len],&ulEncr yptedData3L en);if (rv !=CKROK ){/*错误处理*/}.}需要注意的是,对于CryptoKi 来说,应用程序包含一个独立的地址空间及其中的控制线程.应用程序首先需要从其中一个线程调用C Initialize 函数来使用CryptoKi 接口.此后该应用程序才能调用其它CryptoKi 函数.应用程序完成CryptoKi 的使用后,应当调用CryptoKi 函数C Finalize 以退出.因此在使用CryptoKi 时,需要注意以上过程对于进程和线程要有不同的处理.1)假定进程P 通过调用C Initialize 完成CryptoKi 库的初始化后,调用fork 产生了进程C,P 和C 拥有独立的进程空间.此时如果C 需要使用CryptoKi 接口,则必须使用C Initialize 重新进行初始化.否则,理论上对CryptoKi 接口的调用应当返回CKR CRYPTOKI NOT INIT IALIZED 。
pkcs10certificationrequest 公钥 -回复
pkcs10certificationrequest 公钥-回复题目:PKCS10 Certification Request公钥摘要:PKCS10(公钥证书请求语法)是一种密钥生成应用程序接口(API),用于提交公钥证书请求给证书颁发机构(CA)。
本文将一步一步介绍PKCS10 Certification Request公钥的相关概念、步骤和应用,以及与其他证书请求格式的比较。
引言:公钥证书在现代的互联网通信中扮演着重要的角色,它用于认证和加密通信。
PKCS10 Certification Request是一种用于生成公钥证书请求的规范,它定义了证书的格式、内容和结构。
本文将详细解释PKCS10 Certification Request公钥的相关概念和应用。
一、PKCS10 Certification Request公钥的定义PKCS10 Certification Request是一种以ASN.1(抽象语法记法一)为基础的格式,用于将公钥证书请求信息编码成二进制形式。
ASN.1是一种标准的描述消息结构的语法,它定义了数据结构以及如何在计算机网络中进行编码和传输。
二、PKCS10 Certification Request的生成步骤1. 生成密钥对:首先,需要生成一对密钥,包括公钥和私钥。
这对密钥通常使用RSA算法或椭圆曲线加密(ECC)算法生成。
2. 构建证书请求:使用生成的密钥对,将待请求的证书信息填入PKCS10 Certification Request的各个字段中。
这些字段包括申请者的名称、公钥、密钥用法等。
3. 编码证书请求:将构建好的证书请求信息使用ASN.1进行编码,生成二进制形式的PKCS10 Certification Request。
4. 提交证书请求:将生成的证书请求发送给证书颁发机构(CA),以便后续的证书签发流程。
通常,证书请求会经过加密和签名等处理,确保请求的安全性和可信度。
pk12util用法 -回复
pk12util用法-回复pk12util是一个用于管理PKCS #12文件的命令行工具。
PKCS #12是一种标准的加密文件格式,常用于存储加密证书、私钥和其他相关信息。
pk12util提供了一系列命令,可用于生成、导入、导出、浏览和验证PKCS #12文件。
一、pk12util的安装和基本用法首先,我们需要安装pk12util工具。
pk12util是NSS(Network Security Services)软件包的一部分,因此我们需要先安装NSS。
在Linux系统上,可以通过包管理器来安装NSS。
例如,在Debian/Ubuntu系统上,可以使用以下命令来安装NSS和pk12util:sudo apt-get install libnss3-tools安装完成后,我们就可以开始使用pk12util来管理PKCS #12文件了。
1. 生成PKCS #12文件要生成一个PKCS #12文件,首先需要有一个包含证书和私钥的数据库。
可以使用certutil工具来创建和管理该数据库。
假设我们已经有了一个数据库,其中包含了一个证书和相应的私钥。
要生成PKCS #12文件,可以使用以下命令:pk12util -o output.p12 -n "My Certificate" -d /path/to/database -k /path/to/private/key上述命令将生成一个名为output.p12的PKCS #12文件,其中包含了指定的证书和私钥。
2. 导入PKCS #12文件到数据库如果我们已经有了一个PKCS #12文件,想要将其中的证书和私钥导入数据库,可以使用以下命令:pk12util -i input.p12 -d /path/to/database上述命令将导入input.p12文件中的证书和私钥到指定的数据库中。
3. 导出PKCS #12文件如果我们想要将数据库中的证书和私钥导出为PKCS #12文件,可以使用以下命令:pk12util -o output.p12 -n "My Certificate" -d /path/to/database上述命令将从指定的数据库中导出名为"My Certificate"的证书和私钥,并保存到output.p12文件中。
PKCS #1 v2.1 RSA 算法标准
5.1.1 5.1.2 5.2 5.2.1 5.2.1 6 7
签名和验证原语 ................................................................................................................................................. 12
加密运算 ...................................................................................................................................................... 22 7.2.2 解密运算 ...................................................................................................................................................... 23
7.1.1 7.2 RSAES-PKCS1-V1_5............................................................................................................................................................................................................................................................................ 17 7.1.2 解密运算 ...................................................................................................................................................... 20
cnpkcs10v1_7(认证请求语法标准)
组织:PKI 论坛(.cn )PKCS/PKIX 中文翻译计划论坛电子邮件:pki@译者:sql2000 (付少庆) ()版权:本中文翻译文档版权归PKI论坛的注册用户所共有。
可以用于非商业用途自由转载,但必须保留本文档的翻译及版权信息。
如用于商业目的,所得利润需用于PKI 论坛的发展。
更改记录* 修改类型分为C- 产生一- 附加的M- 修正D- 划除PKCS#10 v1.7 认证请求语法标准(PKCS#10 v1.7: Certification Request Syntax Standard)RSA 实验室2000 年 5 月 26*目录:1.绪论........................................................................................................ 错误!未定义书签。
2.定义与符号............................................................................................ 错误!未定义书签。
2.1定义............................................................................................. 错误!未定义书签。
2.2符号............................................................................................. 错误!未定义书签。
3.概述..................................................................................................... 错误!未定义书签。
cn_pkcs_8v1.2
组织:PKI论坛()PKCS/PKIX中文翻译计划论坛E-mail:pki@译者:timper (timper@)版权:本中文翻译文档版权归PKI论坛的注册用户所共有。
可以用于非商业用途自由转载,但必须保留本文档的翻译及版权信息。
如用于商业目的,所得利润需用于PKI论坛的发展。
更改记录PKCS#8 私钥信息语法格式(PKCS#8: Private-Key Information Syntax Standard)RSA 实验室技术摘记修订版1.2-1993年11月1日*1.范围本文描述一种私钥信息的语法。
私钥信息包含一个对应于某个公钥算法的私钥和一个属性集。
本文还描述一种加密密钥的语法。
基于口令的加密算法(例如在PKCS#5中描述的某一种算法)可以用来加密私钥信息。
包含属性集的目的是通过属性信息为用户提供一个快捷的方式确立信任,如辨识名(DN)或顶级证书权威机构(CA)的公钥等信息。
尽管这样的信任可通过数字签名确立,但使用只有用户知道的密钥加密过程同样高效并易于实现。
详细的属性列表在PKCS#9中描述。
2.参考文献PKCS #1 RSA Laboratories. PKCS #1: RSA Encryption Standard.V ersion 1.5, November 1993.*替代1991年6月的版本,同时也作为NIST/OSI执行工作组的文档SEC-SIG-91-23发布。
PKCS文档可通过电子邮件发送到<pkcs@>获取。
版权说明:Copyright 1991–1993 RSA Laboratories, a division of RSA Data Security, Inc. License to copy this document is granted provided that it is identified as "RSA Data Security, Inc. Public-Key Cryptography Standards (PKCS)" in all material mentioning or referencing this document.003-903023-120-000-000PKCS#5 RSA Laboratories. PKCS #5: Password-Based Encryption Standard.V ersion 1.5, November 1993.PKCS #9 RSA Laboratories. PKCS #9: Selected Attribute Types. V ersion 1.1, November 1993. X.208 CCITT. Recommendation X.208: Specification of Abstract Syntax Notation One (ASN.1). 1988.X.209 CCITT. Recommendation X.209: Specification of Basic Encoding Rules for Abstract Syntax Notation One (ASN.1). 1988.X.501 CCITT. Recommendation X.501: The Directory–Models. 1988.X.509 CCITT. Recommendation X.509: The Directory–Authentication Framework. 1988.3.定义出于标准格式的目的,本文应用了下列定义。
pkcks方法论
pkcks方法论PKCS(Public Key Cryptography Standards,公钥密码学标准)是由美国RSA Data Security(现为EMC Corporation旗下的RSA安全分部)定义的一系列公钥密码学相关的标准。
PKCS#1:RSA加密标准PKCS#1是最早的公钥密码标准之一,详细说明了RSA加密和解密算法及其实现过程。
PKCS#1标准并不涉及密钥管理和证书格式。
PKCS#3:Diffie-Hellman密钥交换标准PKCS#3是一种密钥交换协议,使用基于离散对数问题的Diffie-Hellman算法交换密钥。
PKCS#3还提供了使用Diffie-Hellman交换的密钥派生协议。
PKCS#5:基于口令的加密标准PKCS#5标准定义了一种基于口令的加密算法,被广泛应用于文档加密和密码保护。
PKCS#5使用基于口令的密钥派生函数(Password-Based Key Derivation Function,PBKDF),根据用户提供的口令和随机盐生成对称密钥。
PKCS#6:扩展证书语法标准PKCS#6定义了一种扩展证书语法(Extended Certificate Syntax),包括扩展证书和扩展证书吊销列表。
该标准允许在X.509证书中包含非标准扩展字段。
PKCS#7:加密消息语法标准PKCS#7定义了一种加密消息语法(Cryptographic Message Syntax,CMS),用于加密、签名和验证消息。
CMS支持多种消息格式和数字签名算法,可以进行文件加密、邮件加密等安全通信。
PKCS#8:私钥信息标准PKCS#8定义了一种格式化表示私钥的方法,用于存储和交换私钥。
PKCS#8支持多种非对称加密算法,如RSA、DSA、EC和DH。
PKCS#9:扩展安全标记语法标准PKCS#9定义了一种扩展安全标记语法(Extended Security MarkUp Language,ESML),用于在数字证书中包含附加信息。
pkcs7证书格式解析
pkcs7证书格式解析PKCS#7证书格式解析PKCS#7(公钥密码编码标准)是一种证书格式,它用于在公钥基础设施(PKI)中传输和存储数字证书、私钥和其他相关加密数据。
PKCS#7证书格式广泛应用于数字签名、消息加密和认证服务中。
PKCS#7证书格式采用ASN.1(抽象语法标记)来描述证书结构。
这种格式使用一种基于二进制的编码方式,以确保数据的完整性和安全性。
PKCS#7证书主要由以下几个部分组成:1. 证书链:PKCS#7证书可以包含多个证书,其中包括密钥交换证书、身份验证证书和根证书等。
证书链被用于验证数字证书的有效性和身份。
2. 签名:PKCS#7证书可以包含一个或多个数字签名。
数字签名用于验证数据的完整性和身份。
签名通常使用证书中包含的私钥生成,并可以通过验证证书链来验证签名的有效性。
3. 加密数据:PKCS#7证书可以包含加密的数据,用于保护敏感信息的机密性。
加密数据通常使用证书中包含的公钥进行加密,并可以使用相应的私钥进行解密。
4. 杂项信息:PKCS#7证书还可以包含其他杂项信息,如时间戳、证书撤销列表(CRL)等。
解析PKCS#7证书主要涉及以下步骤:1.使用特定的编码方式(如DER或PEM)将证书数据转换为二进制格式。
2.根据ASN.1结构解析证书,识别证书的各个组成部分。
3.验证证书链,确保每个证书有效且可以信任。
4.检查证书中的数字签名,验证数据的完整性和身份。
5.如果证书包含加密数据,则使用相应的私钥进行解密。
PKCS#7证书格式的解析对于安全领域和网络通信至关重要。
通过了解PKCS#7证书的结构和内容,我们可以确保证书的有效性、数据的完整性和机密性,从而提高网络通信的安全性。
rsa pkcs-1填充方式
根据这个要求,对于512bit的密钥, block length = 512/8 – 11 = 53 字节
2) RSA_PKCS1_OAEP_PADDING
RSA_size(rsa) – 41
3)for RSA_NO_PADDING 不填充
RSA_size(rsa)
c 密文
输出: m 明文
步骤:
1. 如果密文c不满足 0 < c < n-1, 输出 'ciphertext repersentative out of range'
2. 按照如下方法计算m:
a. 如果使用私钥K的第一种形式(n, d), 就让 m = c^d % n (c的d次幂,除以n,余数为m)
步骤:
1. 如果m不满足 0 2. 让 c = m^e % n (m的e次幂 除以n ,余数为c)
3. 输出 c
解密原理 RSADP (K, c)
输入: K RSA私钥,K由下面形式:
一对(n,d)
一个五元组(p, q, dP, dQ, qInv)
一个可能为空的三元序列(ri, di, ti), i=3,...,u
m = RSAVP1 ((n, e), s)
c) 将m 转换成编码的消息EM,长度 emLen = [ (modBits -1)/8 ] 字节。 modBits是RSA modulus n的位长
EM = I2OSP (m, emLen)
注意: 如果 modBits-1可以被8整除,那么emLen = k-1,否则 emLen = k
m = RSADP((n,d), c)
如果RSADP输出'ciphertext representative out of range'(意味c>=n), 就输出’decryption error”
PKCS#1v2.1RSA密码学规范
P K C S#1v2.1:R S A密码学规范RSA实验室2002年6月14日--翻译:CaesarZou1.介绍这个文档提供了基于RSA算法的公钥密码学的建议实现,包含如下的方面:>密码学单元>加密方案>带填充的签名方案>以ASN.1语法展现的密钥和方案参考建议基于计算机的通用需求和通讯系统,并且引入了合适数量的灵活性。
建议基于这个规范的应用标准可以包含额外的限制。
参考建议尝试与IEEE-1353-2000和当前ANSIX9F1开发的讨论版本规范以及IEEEP1363[27]工作组兼容。
这个文档取代PKCS#1版本2.0。
但是包含兼容的技术。
这个文档的组织结构如下:>第一章是一个介绍。
>第二章定义了这个文档中使用的一些符号。
>第三章定义了RSA公钥和四要类型。
>第四章和第五章定义了一些单元或者数学操作的基本单位。
>第六章第七章和第八章解决了这个文档中加密和签名的方案。
第六章给出了一个综述,沿着PKCS$1v1.5定义的方法,第七章定义了OAEP基础的加密算法,第八章定义了PSS基础的填充签名算法。
>第九章定义了第八章定义的签名算法的编码方法。
附录A定义了第三章定义的密钥以及第七章第八章定义的算法的ASN.1语法标识。
附录B定义了这个文档中使用的哈希函数和掩码生成算法。
包含算法的ASN.1语法标识。
附录C给出了一个ASN.1模块附录D,E,F和G包含了一些常见问题,PKCS#1的版本历史,给出到其它出版物和规范的引用,并提供关于公钥算法规范的基本信息。
2符号c密文标识,是一个0到n-1大小的整数。
C密文标识,一个字符串dRSA私有指数diri的CRT指数的附加因子,一个正整数满足e*di≡1(mod(ri-1)),i=3,....,u dPp的CRT指数,一个正整数满足e*dP≡1(mod(p-1))dQq的CRT指数,一个正整数满足e*dQ≡1(mod(q-1))eRSA公有指数EM编码消息,一个字节串emBits一个编码消息EM的比特长度emLen一个编码消息EM的字节长度GCD两个正整数的最大公约数Hash哈希函数hLen哈希函数Hash输出的字节长度kRSA模数n的字节长度KRSA私钥L可选的RSAES-OAEP标签,一个字节串LCM一系列正整数的最小公倍数m消息标识,一个0到n-1的整数M消息,一个字节串maskMGF的输出,一个字节串mgfSeedmask生成的种子,一个字节串mLen消息M的字节长度nRSA模数,n=r1*r2*....ru,u>=2(n,e)RSA公钥p,qRSA模数n的第一分解因子qinvCRT西数,一个小于p的正整数,满足q.qinv≡1(modp)riRSA模数的主因子,包含r1=p,r2=q,如果有的话也包含额外的因子。
cn-pkcs#7
PKCS #7:加密消息语法标准(Cryptographic Message Syntax Standard)An RSA Laboratories Technical NoteVersion 1.5Revised November 1, 1993*1. 范围这一标准描述了待加密数据的一般语法,比如数字签名和数字信封。
该语法允许递归,如一个信封能够包含在另一个当中,或者一方能够对一已存在的封装数据进行签名。
它也允许专有的属性和消息的内容一起被鉴别,比如签名时间,并且提供其他属性如伴随着签名的连属(countersignature)。
该语法的一个简化版提供了发布证书和CRL的方法。
这一标准和PEM(Privacy-Enhance Mail)兼容,体现在签名数据和签名并封装的数据内容上,以一种PEM兼容格式构成,并能够在无需任何加密操作的情况下转换成PEM消息。
类似地,PEM消息也能转换成签名数据和签名封装数据的内容格式。
这一标准能够支持多种基于认证的密钥管理体系结构,比如它的一个提议已收录在PEM[RFC1422]中。
一些体系结构上的决定比如何种证书颁发者才是“顶级”的,何种实体证书颁发者应被授权,何种可辨别名能够被接受以及颁发者应该遵循怎样的证书策略等等这些问题不在本标准讨论范围之内。
由这一标准产生的值可能是BER编码的,这意味着该值会以8位字节串(octet string)的形式表示。
众所周知,虽然许多系统能够可靠地传输专有的8位字节串,但很多电子邮件系统并没有这么做。
这一标准并不寻找编码8位字节串的机制,像ASCII字符串或者其他保证可靠传输的re-encoding 8位字节串技术。
RFC 1421 对该问题提出了可能的解决方法。
2. 参考FIPS PUB 46–1 National Bureau of Standards. FIPS PUB 46–1: Data Encryption Standard. January 1988.PKCS #1 RSA Laboratories. PKCS #1: RSA Encryption Standard. Version 1.5, November 1993.PKCS #6 RSA Laboratories. PKCS #6: Extended-Certificate Syntax Standard. Version 1.5, November 1993.*Supersedes June 3, 1991 version, which was also published as NIST/OSI Implementors' Workshop document SEC-SIG-91-22. PKCS documents are available by electronic mail to .PKCS #9 RSA Laboratories. PKCS #9: Selected Attribute Types. Version 1.1, November 1993.RFC 1421 J. Linn. RFC 1421: Privacy Enhancement for Internet Electronic Mail: Part I: Message Encryption and Authentication Procedures. February 1993.RFC 1422 S. Kent. RFC 1422: Privacy Enhancement for Internet Electronic Mail: Part II: Certificate-Based Key Management. February 1993.RFC 1423 D. Balenson. RFC 1423: Privacy Enhancement for Internet Electronic Mail: Part III: Algorithms, Modes, and Identifiers. February 1993.RFC 1424 B. Kaliski. RFC 1424: Privacy Enhancement for Internet Electronic Mail: Part IV: Key Certification and Related Services. February 1993.RFC 1319 B. Kaliski. RFC 1319: The MD2 Message-Digest Algorithm. April 1992.RFC 1321 R. Rivest. RFC 1321: The MD5 Message-Digest Algorithm. April 1992.X.208 CCITT. Recommendation X.208: Specification of Abstract Syntax Notation One (ASN.1). 1988.X.209 CCITT. Recommendation X.209: Specification of Basic Encoding Rules for Abstract Syntax Notation One (ASN.1). 1988.X.500 CCITT. Recommendation X.500: The Directory—Overview of Concepts, Models and Services. 1988.X.501 CCITT. Recommendation X.501: The Directory—Models. 1988.X.509 CCITT. Recommendation X.509: The Directory—Authentication Framework. 1988.[NIST91] NIST. Special Publication 500-202: Stable Implementation Agreements for Open Systems Interconnection Protocols. Version 5, Edition 1, Part 12. December 1991.[RSA78] R.L. Rivest, A. Shamir, and L. Adleman. A method for obtaining digital signatures and public-key cryptosystems. Communications of the ACM, 21(2):120–126, February 1978.3. 定义For the purposes of this standard, the following definitions apply.AlgorithmIdentifier: A type that identifies an algorithm (by object identifier) and associated parameters. This type is defined in X.509.ASN.1: Abstract Syntax Notation One, as defined in X.208.Attribute: A type that contains an attribute type (specified by object identifier) and one or more attribute values. This type is defined in X.501.BER: Basic Encoding Rules, as defined in X.209.Certificate: A type that binds an entity's distinguished name to a public key with a digital signature. This type is defined in X.509. This type also contains the distinguished name of the certificate issuer (the signer), an issuer-specific serial number, the issuer's signature algorithm identifier, and a validity period.CertificateSerialNumber: A type that uniquely identifies a certificate (and thereby an entity and a public key) among those signed by a particular certificate issuer. This type is defined in X.509.CertificateRevocationList: A type that contains information about certificates whose validity an issuer has prematurely revoked. The information consists of an issuer name, the time of issue, the next scheduled time of issue, and a list of certificate serial numbers and their associated revocation times. The CRL is signed by the issuer. The type intended by this standard is the one defined RFC 1422.DER: Distinguished Encoding Rules for ASN.1, as defined in X.509, Section 8.7.DES: Data Encryption Standard, as defined in FIPS PUB 46-1.desCBC: The object identifier for DES in cipher-block chaining (CBC) mode, as defined in [NIST91].ExtendedCertificate: A type that consists of an X.509 public-key certificate and a set of attributes, collectively signed by the issuer of the X.509 public-key certificate. This type is defined in PKCS #6.MD2: RSA Data Security, Inc.'s MD2 message-digest algorithm, as defined in RFC 1319.md2: The object identifier for MD2, as defined in RFC 1319.MD5: RSA Data Security, Inc.'s MD5 message-digest algorithm, as defined in RFC 1321.md5: The object identifier for MD5, as defined in RFC 1321.Name: A type that uniquely identifies or "distinguishes" objects in an X.500 directory. This type is defined in X.501. In an X.509 certificate, the type identifies the certificate issuer and the entity whose public key is certified.PEM: Internet Privacy-Enhanced Mail, as defined in RFCs 1421–1424.RSA: The RSA public-key cryptosystem, as defined in [RSA78].rsaEncryption: The object identifier for RSA encryption, as defined in PKCS #1.4. 符号和缩略语No symbols or abbreviations are defined in this standard.5. 概述下面的9节指定了有用的类型,通用的语法,六种内容类型和对象标识符。
pkcs证书的使用
pkcs证书的使用
PKCS(Public Key Cryptography Standards,公钥密码学标准)是一系列密码学标准,其中包括关于证书和密钥等密码学实体的定义和规范。
PKCS#12是PKCS标准中的一部分,它定义了一种通用的文件格式,用于存储和传输个人身份证书、私钥和其他相关信息。
PKCS#12文件通常使用.p12或.pfx扩展名。
PKCS#12证书通常用于以下情况:
1.数字身份验证:PKCS#12证书包含个人身份证书和私钥,用于证明某人或某个实体的身份。
这种证书通常用于网络身份验证、电子邮件签名和加密等场景。
2.客户端证书:在一些安全通信协议中,客户端需要提供自己的证书来验证身份。
PKCS#12证书可以用作客户端证书,以便安全地建立与服务器的通信。
3.SSL/TLS通信:在SSL/TLS协议中,服务器端通常使用X.509格式的证书来验证身份,而客户端可以使用PKCS#12证书来提供自己的身份。
4.数字签名:PKCS#12证书中包含私钥,可以用于生成数字签名,以证明信息的完整性和身份验证。
要使用PKCS#12证书,您需要以下步骤:
5.获取PKCS#12证书:通常,您可以从证书颁发机构(CA)或相关的证书服务提供商处获得PKCS#12证书。
6.导入证书:使用适当的工具(如操作系统的证书管理工具、安全浏览器或密码学库),导入PKCS#12证书到您的操作系统或应用程序中。
7.使用证书:一旦导入成功,您可以在您的应用程序或系统中使用证书,例如进行安全通信、身份验证、数字签名等操作。
pkcs7.verify 原理
pkcs7.verify 原理PKCS#7是一个标准的消息认证码(MAC)和数字签名结构,它用于验证数据的完整性和真实性。
在PKCS#7中,数据可以是任意长度的,并且可以包含多个签名和/或加密的内容。
验证过程主要是确定数据在传输过程中是否被篡改,以及数字签名是否有效。
下面是PKCS#7验证的主要步骤和逻辑:1.签名算法和密钥管理:o PKCS#7支持多种签名算法,如RSA、DSA等。
在生成数字签名时,需要使用发送方的私钥。
而在验证时,则需要使用相应的公钥。
o密钥的管理方式依赖于具体的实现和部署环境,通常会采用中心化的密钥管理系统或基于P2P的分布式系统。
2.数据完整性验证:o发送方在发送数据前,会使用散列函数(如SHA-256)对原始数据进行散列处理,生成一个固定长度的散列值。
这个散列值会与数字签名一起发送给接收方。
o接收方收到数据后,同样使用相同的散列函数对数据进行散列处理,然后与发送方提供的散列值进行比对。
如果两者一致,说明数据在传输过程中没有被篡改。
3.数字签名验证:o数字签名用于验证数据的来源和完整性。
发送方使用自己的私钥对数据的散列值进行加密,生成数字签名。
这个签名会附加在数据之后发送给接收方。
o接收方使用发送方的公钥对数字签名进行解密,如果解密成功且得到的散列值与接收到的散列值一致,则说明数字签名有效,数据是真实且未被篡改的。
4.证书链验证:o在实际应用中,公钥通常不是直接发送给接收方的,而是通过第三方证书颁发机构(CA)进行签名的。
因此,接收方在验证数字签名之前,还需要验证公钥证书的合法性。
o这涉及到证书链的验证:验证CA的证书是否有效,CA证书是否是由可信任的根证书颁发机构签名等。
5.时间戳和有效期:o数字签名和证书都可能包含时间戳和有效期信息。
这些信息用于确保数字签名和证书在当前时间点是有效的。
如果超过有效期或时间戳显示签名是在未来生成的,则验证失败。
6.错误处理和日志记录:o在验证过程中,如果遇到任何错误(如数据完整性损坏、数字签名无效等),验证函数应返回错误信息并停止验证过程。
Python--AES-ECB-pkcs5padding-base64加密与解密
Python--AES-ECB-pkcs5padding-base64加密与解密python3下载:pip install crypto pycryptodomeimport base64from Crypto.Cipher import AESclass EncryptDate:def__init__(self, key):self.key = key # 初始化密钥self.length = AES.block_size # 初始化数据块⼤⼩self.aes = AES.new(self.key, AES.MODE_ECB) # 初始化AES,ECB模式的实例# 截断函数,去除填充的字符self.unpad = lambda date: date[0:-ord(date[-1])]def pad(self, text):"""#填充函数,使被加密数据的字节码长度是block_size的整数倍"""count = len(text.encode('utf-8'))add = self.length - (count % self.length)entext = text + (chr(add) * add)return entextdef encrypt(self, encrData): # 加密函数res = self.aes.encrypt(self.pad(encrData).encode("utf8"))msg = str(base64.b64encode(res), encoding="utf8")return msg# def decrypt(self, decrData): # 解密函数# res = base64.decodebytes(decrData.encode("utf8"))# msg = self.aes.decrypt(res).decode("utf8")# return self.unpad(msg)def get_aes_pwd(password):# 这⾥密钥的长度必须是16的倍数加密的时候需要的是⼆进制类型⽽不是⽂本类型,字符串前⾯加上beg = EncryptDate(b"key")res = eg.encrypt(password)return resif__name__ == "__main__":pwd = "明⽂密码"aes_pwd = get_aes_pwd(pwd)print(aes_pwd)。
密码学系列之:PEM 和 PKCS7,PKCS8,PKCS12
密码学系列之:PEM 和PKCS7,PKCS8,PKCS12简介PEM 是一种常见的保存key 或者证书的格式,PEM 格式的文件一般来说后缀是以.pem 结尾的。
那么PEM 到底是什么呢?它和常用的证书格式PKCS7 和PKCS12 有什么关系呢?一起来看看吧。
PEMPEM 虽然使用来存储证书或者密钥的,但是PEM 原本是和email 相关联的,因为PEM 的全称是Privacy-Enhanced Mail, 最初是为邮件的隐私增强而创建的,是在1993 年由IETF 制定的标准。
虽然最终的协议标准并没有被广泛采用,但是其中定义的文本编码却被广泛的使用,最终由IETF 在RFC 7468 中正式化。
之前我们介绍过一种协议描述语言ASN.1,ASN.1 通常被用来定义协议中的数据结构,然后通过使用DER 编码来对这些数据进行序列化,但是DER 编码是二进制的格式,二进制文件在某些情况下不方便进行传输或者展示,不然说某些只支持ASCII 编码的情况,所以需要一种可以讲DER 格式转换成为文本格式的方式。
这种方式就叫做PEM。
PEM 使用的方法也很简单,就是对DER 编码过后的二进制数据使用base64 编码,将其转换成为文本文件。
在PEM 中有固定的文件头和文件结尾符。
文件头是以’—–BEGIN’+label+’—–‘开始,文件结尾是以’—–END’+label+’—–‘结束。
其中label 表示的是编码的消息类型,通常可以取这些值:CERTIFICATE, CERTIFICATE REQUEST, PRIVATE KEY 和X509 CRL。
下面是一个PEM 的例子,表示其内容是一个证书:-----BEGIN CERTIFICATE KEY----------END CERTIFICATE KEY-----虽然PEM 格式的文件通常以.pem 结束,但是也可以使用“.cer” 或者“.crt” 表示一个证书,使用”.key” 表示是一个密钥。
enp2s0 命名规则
enp2s0 命名规则1. 什么是 enp2s0?enp2s0 是一个网络接口的命名规则,它常用于 Linux 操作系统中。
在 Linux 中,网络接口是指计算机用来连接到网络的硬件或软件设备。
每个网络接口都需要一个唯一的标识符,以便操作系统能够正确地识别和管理它们。
2. 命名规则解释enp2s0 是根据一种命名规则来命名网络接口的。
这种规则通常被称为Predictable Network Interface Names(可预测的网络接口命名)。
它的设计目的是提供一种一致且可预测的命名方案,以便更容易识别和管理网络接口。
enp2s0 的命名规则由三个部分组成:前缀、槽位和端口。
下面对每个部分进行详细解释:2.1 前缀前缀是命名规则的第一个部分,它用于标识网络接口的类型。
在 enp2s0 中,“en” 是以太网(Ethernet)的缩写,表示这个网络接口是通过以太网进行连接的。
其他常见的前缀还包括“wl”(无线局域网)和“ww”(无线广域网)。
2.2 槽位槽位是命名规则的第二个部分,它用于标识网络接口所在的插槽或位置。
在enp2s0 中,“2” 表示这个网络接口位于第二个插槽。
槽位的编号通常是根据硬件设备的物理连接顺序来确定的。
2.3 端口端口是命名规则的第三个部分,它用于标识网络接口所连接的端口。
在 enp2s0 中,“s0” 表示这个网络接口连接到系统的第一个端口。
如果一个系统有多个网络接口连接到同一个端口,那么它们的端口标识会依次递增,例如 s1、s2 等。
3. 为什么需要可预测的接口命名?可预测的网络接口命名方案有以下几个优点:3.1 易于识别和管理通过使用可预测的命名规则,管理员可以更容易地识别和管理网络接口。
命名规则中的前缀和编号提供了关于网络接口类型和位置的信息,使管理员能够快速定位和操作特定的接口。
3.2 避免命名冲突使用可预测的命名规则可以避免网络接口命名冲突的问题。
每个网络接口都有一个唯一的标识符,这样就可以确保不同的接口之间不会发生命名冲突,避免了潜在的混乱和错误。
python笔记66-DESCBCpkcs5padding加解密(pyDes)
python笔记66-DESCBCpkcs5padding加解密(pyDes)前⾔使⽤python代码实现 DES/CBC/pkcs5padding加解密DES加密模式加密模式:DES/CBC/pkcs5padding加解密在线⼯具:需知道加密的密码(8位):yoyo1234IV偏移量(8位):12345678输出编码格式(16进制):hex在线加密结果输⼊:yoyo得到16进制:d50d7e20173f0e27pyDes库先安装pyDes库Version: 2.0.1> pip install pyDespython代码实现DES加解密from pyDes import des, CBC, PAD_PKCS5import binascii"""加密模式:DES/CBC/pkcs5padding需pip先安装依赖包> pip install pyDes"""def des_encrypt(s, key='yoyo1234'):"""DES 加密:param s: 原始字符串:param key: 加密密钥8位:return: 加密后字符串,16进制"""secret_key = keyiv = '12345678' # 偏移量8位k = des(secret_key, CBC, iv, pad=None, padmode=PAD_PKCS5)en = k.encrypt(s, padmode=PAD_PKCS5)return binascii.b2a_hex(en)def des_descrypt(s, key='yoyo1234'):"""DES 解密:param s: 加密后的字符串,16进制:return: 解密后的字符串"""secret_key = keyiv = '12345678' # 偏移量8位k = des(secret_key, CBC, iv, pad=None, padmode=PAD_PKCS5) de = k.decrypt(binascii.a2b_hex(s), padmode=PAD_PKCS5)return deif __name__ == '__main__':s = 'yoyo'encry_s = des_encrypt(s)print(encry_s)descry_s = des_descrypt(encry_s)print(descry_s)运⾏结果b'd50d7e20173f0e27'b'yoyo'加解密AES/CBC/pkcs7padding加解密参考。
pkcs证书校验流程
pkcs证书校验流程
PKCS证书校验流程是一种广泛使用的安全算法,用于验证证书的合法性和完
整性。
以下是PKCS证书校验流程的详细步骤。
首先,需要从信任的证书颁发机构(CA)处获取根证书,根证书包含了公钥
和CA的数字签名。
然后,从连接的服务器或服务获取被验证证书,该证书包含了公钥和数字签名。
接下来,使用根证书的公钥来验证根证书的数字签名。
如果验证通过,则表示
根证书是受信任的。
随后,使用根证书的公钥来验证被验证证书的数字签名。
如果验证通过,则表
示被验证证书是有效的。
此外,还需要验证被验证证书中的有效期。
确保当前时间在证书的有效期范围内。
另外,还可以验证被验证证书的颁发者与根证书的颁发者是否相同,确保证书
的完整性。
最后,可以使用被验证证书中的公钥进行数据加密或数字签名验证等操作。
总结一下,PKCS证书校验流程包括获取根证书、验证根证书的数字签名、获
取被验证证书、验证被验证证书的数字签名、验证证书的有效期、验证证书的完整性以及使用证书进行安全操作。
这个流程可以确保证书的合法性和完整性,为网络通信提供了安全保障。
Python实现常见的几种加密算法(MD5,SHA-1,HMAC,DESAES,RSA和ECC)
Python实现常见的⼏种加密算法(MD5,SHA-1,HMAC,DESAES,RSA和ECC)⽣活中我们经常会遇到⼀些加密算法,今天我们就聊聊这些加密算法的Python实现。
部分常⽤的加密⽅法基本都有对应的Python库,基本不再需要我们⽤代码实现具体算法。
MD5加密全称:MD5消息摘要算法(英语:MD5 Message-Digest Algorithm),⼀种被⼴泛使⽤的密码散列函数,可以产⽣出⼀个128位(16字节)的散列值(hash value),⽤于确保信息传输完整⼀致。
md5加密算法是不可逆的,所以解密⼀般都是通过暴⼒穷举⽅法,通过⽹站的接⼝实现解密。
Python代码:import hashlibm = hashlib.md5()m.update(str.encode("utf8"))print(m.hexdigest())SHA1加密全称:安全哈希算法(Secure Hash Algorithm)主要适⽤于数字签名标准(Digital Signature Standard DSS)⾥⾯定义的数字签名算法(Digital Signature Algorithm DSA),SHA1⽐MD5的安全性更强。
对于长度⼩于2^ 64位的消息,SHA1会产⽣⼀个160位的消息摘要。
Python代码: import hashlibsha1 = hashlib.sha1()data = '2333333'sha1.update(data.encode('utf-8'))sha1_data = sha1.hexdigest()print(sha1_data)HMAC加密全称:散列消息鉴别码(Hash Message Authentication Code), HMAC加密算法是⼀种安全的基于加密hash函数和共享密钥的消息认证协议。
实现原理是⽤公开函数和密钥产⽣⼀个固定长度的值作为认证标识,⽤这个标识鉴别消息的完整性。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
PKCS #8: Private-Key Information Syntax StandardAn RSA Laboratories Technical NoteVersion 1.2Revised November 1, 1993*1. ScopeThis standard describes a syntax for private-key information. Private-key information includes a private key for some public-key algorithm and a set of attributes. The standard also describes a syntax for encrypted private keys. A password-based encryption algorithm (e.g., one of those described in PKCS #5) could be used to encrypt the private-key information.The intention of including a set of attributes is to provide a simple way for a user to establish trust in information such as a distinguished name or a top-level certification authority's public key. While such trust could also be established with a digital signature, encryption with a secret key known only to the user is just as effective and possibly easier to implement. A non-exhaustive list of attributes is given in PKCS #9.2. ReferencesPKCS #1 RSA Laboratories. PKCS #1: RSA Encryption Standard.Version 1.5, November 1993.PKCS #5 RSA Laboratories. PKCS #5: Password-Based Encryption Standard.Version 1.5, November 1993.PKCS #9 RSA Laboratories. PKCS #9: Selected Attribute Types. Version 1.1, November 1993. X.208 CCITT. Recommendation X.208: Specification of Abstract Syntax Notation One (ASN.1). 1988.X.209 CCITT. Recommendation X.209: Specification of Basic Encoding Rules for Abstract Syntax Notation One (ASN.1). 1988.*Supersedes June 3, 1991 version, which was also published as NIST/OSI Implementors' Workshop document SEC-SIG-91-23. PKCS documents are available by electronic mail to <pkcs@>. Copyright 1991–1993 RSA Laboratories, a division of RSA Data Security, Inc. License to copy this document is granted provided that it is identified as "RSA Data Security, Inc. Public-Key Cryptography Standards (PKCS)" in all material mentioning or referencing this document.003-903023-120-000-000Page 2 PKCS#8:P RIVATE-K EY I NFORMATION S YNTAX S TANDARD X.501 CCITT. Recommendation X.501: The Directory–Models. 1988.X.509 CCITT. Recommendation X.509: The Directory–Authentication Framework. 1988. 3. DefinitionsFor the purposes of this standard, the following definitions apply.AlgorithmIdentifier: A type that identifies an algorithm (by object identifier) and any associated parameters. This type is defined in X.509.ASN.1: Abstract Syntax Notation One, as defined in X.208.Attribute: A type that contains an attribute type (specified by object identifier) and one or more attribute values. This type is defined in X.501.BER: Basic Encoding Rules, as defined in X.209.4. Symbols and abbreviationsNo symbols or abbreviations are defined in this standard.5. General overviewThe next two sections specify private-key information syntax and encrypted private-key information syntax.This standard exports two types: PrivateKeyInfo(Section 6) and EncryptedPrivateKeyInfo (Section 7).6. Private-key information syntaxThis section gives the syntax for private-key information.Private-key information shall have ASN.1 type PrivateKeyInfo:PrivateKeyInfo ::= SEQUENCE {version Version,privateKeyAlgorithm PrivateKeyAlgorithmIdentifier,privateKey PrivateKey,attributes [0] IMPLICIT Attributes OPTIONAL }Version ::= INTEGER7.E NCRYPTED PRIVATE-KEY INFORMATION SYNTAX Page 3 PrivateKeyAlgorithmIdentifier ::= AlgorithmIdentifierPrivateKey ::= OCTET STRINGAttributes ::= SET OF AttributeThe fields of type PrivateKeyInfo have the following meanings:∙ version is the syntax version number, for compatibility with future revisions of this standard. It shall be 0 for this version of the standard.∙ privateKeyAlgorithm identifies the private-key algorithm. One example of a private-key algorithm is PKCS #1's rsaEncryption.∙privateKey is an octet string whose contents are the value of the private key.The interpretation of the contents is defined in the registration of the private-keyalgorithm. For an RSA private key, for example, the contents are a BER encodingof a value of type RSAPrivateKey.∙attributes is a set of attributes. These are the extended information that is encrypted along with the private-key information.7. Encrypted private-key information syntaxThis section gives the syntax for encrypted private-key information.Encrypted private-key information shall have ASN.1 type EncryptedPrivateKeyInfo: EncryptedPrivateKeyInfo ::= SEQUENCE {encryptionAlgorithm EncryptionAlgorithmIdentifier,encryptedData EncryptedData }EncryptionAlgorithmIdentifier ::= AlgorithmIdentifierEncryptedData ::= OCTET STRINGThe fields of type EncryptedPrivateKeyInfo have the following meanings:∙encryptionAlgorithm identifies the algorithm under which the private-key information is encrypted. Two examples are PKCS #5'spbeWithMD2AndDES-CBC and pbeWithMD5AndDES-CBC.∙encryptedData is the result of encrypting the private-key information.The encryption process involves the following two steps:1. The private-key information is BER encoded, yielding an octet string.2. The result of step 1 is encrypted with the secret key to give an octet string, theresult of the encryption process.Page 4 PKCS#8:P RIVATE-K EY I NFORMATION S YNTAX S TANDARD Revision historyVersion 1.0Version 1.0 was distributed to participants in RSA Data Security, Inc.'s Public-Key Cryptography Standards meetings in February and March 1991.Version 1.1Version 1.1 is part of the June 3, 1991 initial public release of PKCS. Version 1.1 was published as NIST/OSI Implementors' Workshop document SEC-SIG-91-23.Version 1.2Version 1.2 incorporates several editorial changes, including updates to the references and the addition of a revision history.Author's addressRSA Laboratories (415) 595-7703100 Marine Parkway (415) 595-4126 (fax)Redwood City, CA 94065 USA pkcs-editor@。