一、USBKey 实现身份认证原理.pdf

一、USBKey 实现身份认证原理.pdf

ID:52254501

大小:140.39 KB

页数:4页

时间:2020-03-26

一、USBKey 实现身份认证原理.pdf_第1页
一、USBKey 实现身份认证原理.pdf_第2页
一、USBKey 实现身份认证原理.pdf_第3页
一、USBKey 实现身份认证原理.pdf_第4页
资源描述:

《一、USBKey 实现身份认证原理.pdf》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、一、USBKey实现身份认证原理采用冲击/响应(挑战/应答)的认证方法,登录时在服务器端和客户端同时进行计算,客户端计算前要先验证USERPIN,通过后在硬件中使用HMAC-MD5密钥进行计算,服务器端在服务器上使用软件进行计算,比较计算结果。二、USBKey的优点1、兼容性好USBKey不仅对打印机、扫描仪等设备具有高度的透明性,特别是多个相同的USBKey也可以使用USBHUB并联在一起使用,相互之间不会干扰。2、速度快对于使用USBKey加密后的软件,其运行速度同加密前区别不大,USBKey能够在很短的时

2、间内处理完毕,保证用户程序的顺畅运行。3、使用简便USBKey在API函数调用上从用户角度出发,最大限度简化使用接口。用户能够在很短的时间内掌握USBKey的使用方法,节约开发上所投入的时间。三、高加密强度和身份认证相结合USBKey是全新设计的高强度USBKey,有完整的用户管理。(1)用户必须在超级用户状态下(SOPIN验证通过),通过自己设定的不超过51字节的种子生成PID,以后打开和关闭USBKey都需要通过PID来完成。PID的生成算法是在USBKey内部完成的,而且是不可逆的,也就是说,只有生成者才

3、知道什么样的种子能生成什么样的PID,别的人即使知道PID,同时也能够调用这个计算过程,但因为不知道种子是什么,是无法生成和您相同的PID的硬件,保证了用户的USBKey的独特性。(2)用户在对USBKey中的数据进行读写操作时需要进行USERPIN验证,又增加了一层对软件的保护性。(3)用户可以在配置设备时设为只读,那么USBKey中的数据只可以读取,而不能被更改,密钥也不能被修改,从而保证了锁内数据不被篡改。(4)使用USBKey硬件中的HMAC-MD5算法进行冲击响应身份认证。HMAC-MD5密钥存在US

4、BKey中,该密钥只用于计算,任何人获取不到密钥的内容,保证密钥的安全性。(5)提供了安全方便的外壳加密工具,使加密工作非常简单。四、系统支持USBKey采用无驱设计,使用方便,兼容性好,支持多种操作系统台:全系列Windows、Linux和MAC。包括32位和64位。五、使用USBKey进行身份认证可以应用USBKey进行冲击响应身份认证,替换掉传统的用户名和密码方式,使登录更加安全。其原理如下图所示:在整个认证过程中,采用冲击响应的认证方式。当需要在网络上验证用户身份时,先由客户端向服务器发出一个验证请求。

5、服务器接到此请求后生成一个随机数并通过网络传输给客户端(此为冲击)。客户端将收到的随机数提供给,由使用该随机数与存储在中的密钥进行HMAC-MD5运算并得到一个结果作为认证证据传给服务器(此为响应)。与此同时,服务器也使用该随机数与存储在服务器数据库中的该客户密钥进行HMAC-MD5运算,如果服务器的运算结果与客户端传回的响应结果相同,则认为客户端是一个合法用户。六、原理详解冲击/响应的算法原理可以参见(http://www.rfc-editor.org/rfc/rfc2085.txt)。其中公式原型为:MD5

6、(KXORopad,MD5(KXORipad,text))K:密钥(即分配给不同用户的密钥)text:随机数opad:数值0x5Cipad:数值0x36XOR:异或运算符ET99USBKey在此基础上进行了改进,结合进硬件的特点,使得存储在USBKey中的密钥K也是不可被盗取和得知的。ET99的公式为:MD5(MD5(KXORopad),MD5(MD5(KXORipad),text))我们看到ET99的计算公式中,将KXORopad和KXORipad的结果又分别做了MD5运算。假如分配给客户独有的密钥K为123

7、456,那么K与opad异或的结果再进行MD5运算后的16字节称为K1,K与ipad异或的结果再进行MD5运算后的16字节称为K2,K1+K2拼接后的32字节Kin99作为存入ET99USBKey中密钥区中的密钥(ET99可以存储8个32字节密钥)。这样做的目的有两点:(1)硬件保证32字节的密钥Kin99是无法被导出的。(2)即使通过物理探针分析芯片,得到这32字节,通过拆分得到K1和K2,但由于MD5是成熟的单向散列算法,通过K1和K2是反推不出K的值,因此绝对保证了分配给用户,代表用户身份的K是无法被复制

8、的。那么从公式中就可以一目了然看到整个冲击/响应客户端和服务器端进行计算的过程。ET99中计算:(1)使用K2+text(随机数)拼接后进行MD5运算,产生16字节的结果Rc1。(2)使用K1+Rc1拼接后进行MD5运算,产生客户端计算的结果Rc。服务器端计算:(1)从数据库中取得客户的密钥K。(2)K与ipad异或后进行MD5运算产生16字节的Rs1。(3)Rs1+text(随机数)

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。