登陆注册
178000000031

SSL.TLS.WTLS原理(上)

一 前言

首先要澄清一下名字的混淆:

1 SSL(Secure Socket Layer)是netscape公司设计的主要用于web的安全传输协议

。这种协议在WEB上获得了广泛的应用。

2 IETF(www.ietf.org)将SSL作了标准化,即RFC2246,并将其称为TLS(Transport

Layer Security),从技术上讲,TLS1.0与SSL3.0的差别非常微小。由于本文中

没有涉及两者间的细小差别,本文中这两个名字等价。

3 在WAP的环境下,由于手机及手持设备的处理和存储能力有限,wap论坛(

www.wapforum.org)在TLS的基础上做了简化,提出了WTLS协议(Wireless

Transport Layer Security),以适应无线的特殊环境。

我们从各式各样的文章中得知,SSL可以用于保密的传输,这样我们与web server

之间传输的消息便是“安全的”。

而这种“安全”究竟是怎么实现的,最终有能实现多大程度的保密?本文希望能

用通俗的语言阐明其实现原理。

二 整体结构概览

SSL是一个介于HTTP协议与TCP之间的一个可选层,其位置大致如下:

---------

| HTTP |

---------

| SSL |

---------

| TCP |

---------

| IP |

---------

如果利用SSL协议来访问网页,其步骤如下:

用户:在浏览器的地址栏里输入https://www.sslserver.com

HTTP层:将用户需求翻译成HTTP请求,如

GET /index.htm HTTP/1.1

Host http://www.sslserver.com

SSL层: 借助下层协议的的信道安全的协商出一份加密密钥,并用此密钥来加密

HTTP请求。

TCP层:与web server的443端口建立连接,传递SSL处理后的数据。

接收端与此过程相反。

SSL在TCP之上建立了一个加密通道,通过这一层的数据经过了加密,因此达到保

密的效果。

SSL协议分为两部分:Handshake Protocol和Record Protocol,。其中Handshake

Protocol用来协商密钥,协议的大部分内容就是通信双方如何利用它来安全的协

商出一份密钥。 Record Protocol则定义了传输的格式。

三 需要的加密方面的基础知识

了解SSL原理需要一点点加密的概念,这里把需要的概念做一下简单阐述:

加密一般分为三类,对称加密,非对称加密及单向散列函数。

对称加密:又分分组密码和序列密码。

分组密码是将明文按一定的位长分组,明文组经过加密运算得到密文组,密文组

经过解密运算

(加密运算的逆运算),还原成明文组。

序列密码是指利用少量的密钥(制乱元素)通过某种复杂的运算(密码算法)产

生大量的伪随机位流,用于对明文位流的加密。

解密是指用同样的密钥和密码算法及与加密相同的伪随机位流,用以还原明文位

流。

CBC(Cipher Block Chaining)模式这个词在分组密码中经常会用到,它是指一个

明文分组在被加密之前要与前一个的密文分组进行异或运算。当加密算法用于此

模式的时候除密钥外,还需协商一个初始化向量(IV),这个IV没有实际意义,

只是在第一次计算的时候需要用到而已。采用这种模式的话安全性会有所提高。

分组密码的典型例子为DES,RC5,IDEA。

序列密码的典型例子为RC4。

公钥加密:

简单的说就是加密密钥与解密密钥不同,分私钥和公钥。这种方法大多用于密钥

交换,RSA便是一个我们熟知的例子。

还有一个常用的称作DH,它只能用于密钥交换,不能用来加密。

单向散列函数:

由于信道本身的干扰和人为的破坏,接受到的信息可能与原来发出的信息不同,

一个通用的办法就是加入校验码。

单向散列函数便可用于此用途,一个典型的例子是我们熟知的MD5,它产生128位的

摘要,在现实中用的更多的是安全散列算法(SHA),SHA的早期版本存在问题,

目前用的实际是SHA-1,它可以产生160位的摘要,因此比128位散列更能有效抵

抗穷举攻击。

由于单向散列的算法都是公开的,所以其它人可以先改动原文,再生成另外一份

摘要。解决这个问题的办法可以通过HMAC(RFC 2104),它包含了一个密钥,只有

拥有相同密钥的人才能鉴别这个散列。

四 密钥协商过程

由于对称加密的速度比较慢,所以它一般用于密钥交换,双方通过公钥算法协商

出一份密钥,然后通过对称加密来通信,当然,为了保证数据的完整性,在加密

前要先经过HMAC的处理。

SSL缺省只进行server端的认证,客户端的认证是可选的。以下是其流程图(摘自

TLS协议)。

Client Server

Clienth*llo -------->

Serverh*llo

Certificate*

ServerKeyExchange*

CertificateRequest*

<-------- Serverh*lloDone

Certificate*

ClientKeyExchange

CertificateVerify*

[ChangeCipherSpec]

Finished -------->

[ChangeCipherSpec]

<-------- Finished

Application Data <-------> Application Data

简单的说便是:SSL客户端(也是TCP的客户端)在TCP链接建立之后,发出一个

Clienth*llo来发起握手,这个消息里面包含了自己可实现的算法列表和其它一些

需要的消息,SSL的服务器端会回应一个Serverh*llo,这里面确定了这次通信所

需要的算法,然后发过去自己的证书(里面包含了身份和自己的公钥)。Client

在收到这个消息后会生成一个秘密消息,用SSL服务器的公钥加密后传过去,SSL

服务器端用自己的私钥解密后,会话密钥协商成功,双方可以用同一份会话密钥

来通信了。

五 密钥协商的形象化比喻

如果上面的说明不够清晰,这里我们用个形象的比喻,我们假设A与B通信,A是

SSL客户端,B是SSL服务器端,加密后的消息放在方括号[]里,以突出明文消息的

区别。双方的处理动作的说明用圆括号()括起。

A:我想和你安全的通话,我这里的对称加密算法有DES,RC5,密钥交换算法有RSA

和DH,摘要算法有MD5和SHA。

B:我们用DES-RSA-SHA这对组合好了。

这是我的证书,里面有我的名字和公钥,你拿去验证一下我的身份(把证书发给A

)。

目前没有别的可说的了。

A:(查看证书上B的名字是否无误,并通过手头早已有的CA的证书验证了B的证书

的真实性,如果其中一项有误,发出警告并断开连接,这一步保证了B的公钥的真

实性)

(产生一份秘密消息,这份秘密消息处理后将用作加密密钥,加密初始化向量和

hmac的密钥。将这份秘密消息-协议中称为per_master_secret-用B的公钥加密,

封装成称作ClientKeyExchange的消息。由于用了B的公钥,保证了第三方无法窃

听)

我生成了一份秘密消息,并用你的公钥加密了,给你(把ClientKeyExchange发给

B)

注意,下面我就要用加密的办法给你发消息了!

(将秘密消息进行处理,生成加密密钥,加密初始化向量和hmac的密钥)

[我说完了]

B:(用自己的私钥将ClientKeyExchange中的秘密消息解密出来,然后将秘密消

息进行处理,生成加密密钥,加密初始化向量和hmac的密钥,这时双方已经安全

的协商出一套加密办法了)

注意,我也要开始用加密的办法给你发消息了!

[我说完了]

A: [我的秘密是...]

B: [其它人不会听到的...]

六 加密的计算

上一步讲了密钥的协商,但是还没有阐明是如何利用加密密钥,加密初始化向量

和hmac的密钥来加密消息的。

其实其过程不过如此:

1 借助hmac的密钥,对明文的消息做安全的摘要处理,然后和明文放到一起。

2 借助加密密钥,加密初始化向量加密上面的消息。

七 安全性

SecurityPortal在2000年底有一份文章《The End of SSL and SSH?》激起了很多

的讨论,

目前也有一些成熟的工具如dsniff(http://www.monkey.org/~dugsong/dsniff/

)可以

通过man in the middle攻击来截获https的消息。

从上面的原理可知,SSL的结构是严谨的,问题一般出现在实际不严谨的应用中。

常见的攻击就是

middle in the middle攻击,它是指在A和B通信的同时,有第三方C处于信道的中

间,可以完全

听到A与B通信的消息,并可拦截,替换和添加这些消息。

1 SSL可以允许多种密钥交换算法,而有些算法,如DH,没有证书的概念,这样A

便无法验证B的公钥

和身份的真实性,从而C可以轻易的冒充,用自己的密钥与双方通信,从而窃听到

别人谈话的内容。

而为了防止middle in the middle攻击,应该采用有证书的密钥交换算法。

2 有了证书以后,如果C用自己的证书替换掉原有的证书之后,A的浏览器会弹出

一个警告框进行警告,但又有多少人会注意这个警告呢?

3 由于美国密码出口的限制,IE,netscape等浏览器所支持的加密强度是很弱的

,如果只采用浏览器自带的加密功能的话,理论上存在被破解可能。

同类推荐
  • 看穿人心术,拿来就用

    看穿人心术,拿来就用

    如果能掌握“看穿人心术”,人与人之间的沟通会更有效。本书要为您揭晓的“秘术”有:从弦外之音看人际关系、从外表和动作看本性、听到哪些话值得注意、从口头禅看相处之道、从不同的借口洞悉性格等。只要勤加“修炼”,谁都可以更有心机和技巧地处理好人际关系,让家庭更和睦、让工作环境更舒适。尊敬的书友,本书选载最精华部分供您阅读。留足悬念,同样精彩!
  • 计算机探密

    计算机探密

    黑客的精神态度是很重要的,但技术则更是重要.黑客的态度虽然是无可取代,随著新科技的发明和旧技术的取代,这些工具随时间在慢慢的改变.要成为一位真正的黑客,你必须要能在几天之内将manual内容和你目前己经知道的关连起学会一种新的语言.也就是说,你必会学还了C之外的东西,你至少还要会LIS/P或Perl(Java也正在努力的挤上这个名单;译者注: 我很怀疑这份名单).除了几个重要的hacking常用语言之外,这些语言提供你一些不同的程序设计途径,并且让你在好的方法中学习.
  • 孩子一生最受用的40种能力

    孩子一生最受用的40种能力

    尊敬的书友,本书选载最精华部分供您阅读。留足悬念,同样精彩!本书作者提出的40种能力,对孩子在未来生活中的竞争力是不可缺少的,并相应的为家长提供实际的方法和原则,帮助父母在家庭生活中,如何和孩子共同培养这些能力,开启孩子生命中的优势密码。能力关乎孩子的一生,可以让孩子受益一生,从小培养孩子一生最受用的40种能力,它不仅可以开发孩子的才能和潜力,使其身心得到全面成长与成熟,还能把孩子培养成一个乐观、健康、全面发展的优秀人才。
  • 演讲的艺术
热门推荐
  • 众女抢夫:王爷只爱俏村姑

    众女抢夫:王爷只爱俏村姑

    一个出生在偏远山村的俏皮村姑,一个出生在繁华皇城的俊美王爷,一次相遇,王爷竟无可救药的爱上了这个村姑。村姑接旨进宫学礼仪,王爷封地击破敌军,“凤楠~待我凯旋归来,你嫁我可好?”
  • 神奇宝

    神奇宝

    你是否也幻想过生活在神奇宝贝的世界?————一颗神秘的精灵蛋孵出一只图鉴无法识别的神奇宝贝,一个刚从沉睡中苏醒的少年开始了一段新的旅途……无忧无虑,四处遨游,与神奇宝贝为伴,与大自然相随,这便是神奇宝贝的世界,一个理想中的世界。(求收藏、推荐、评论……)
  • 现代大法师

    现代大法师

    正式版简介:宅男叶枫奇遇穿越而来的大魔导师,从而成为了一名正式的魔法师并加入了国家神秘部门;娱乐版简介:成为魔法师的叶枫从此过上了点烟不用火机,旅行不带矿泉水,出行全部报销,公差有人接送的愉快生活;热血版简介:为了华夏国的安全,魔法师叶枫奋战于第一线,比战火纷飞的战场更加危险的地方,这里有异能者,教会,狼人,吸血鬼,古武者,改造人类以及修真者;高大上版简介:愉快的都市生活,诡异的校园闹鬼,隐秘的西部墓穴,强大的自由联盟,神秘的魔法空间,甚至还有传说中的修真者,这些将一个接一个的进入叶枫的世界之中……真正的简介:此文无后宫,不种马,前几章可能会比较无聊,有兴趣的可以继续看下去。【此书已停更,抱歉~】
  • 我的时光机

    我的时光机

    他是科学怪才,发明时光机。却迷失于时光机中,开始了一段段惊险离奇的经历。他通过时光机,穿梭于各个世界之中,过去未来。有时他是武者,有时是修真者,有时是手持激光武器的未来人。他不择手段,用一切可行的,不可行的,来挽救现在,追寻曾经在记忆里的美好时光。
  • 灵异存在

    灵异存在

    鬼是如何寻找替身的?活人能跟纸扎人结婚吗?活鬼胎究竟算人还是算鬼?冥妻和鬼妻之间有什么不同?古井里的脸为什么会是自己的?百鬼夜行的背后隐藏着什么秘密?我是王希明,一个网络灵异小说作家,一个半吊子的茅山道士,一个灵异事件的当事人!黑天请闭眼!灵异的存在,就在你的身边,你……感受到了吗?
  • 男神的猫

    男神的猫

    穆澈是个继承了大笔遗产的孤儿,与他相伴的只有一只叫做小暖的白色猫咪,突然有一天,猫咪从他的视线消失,一个与他的猫咪同名的女生转到了他的班级,他是老师,却不可抑制的爱上了他的学生,她,究竟是那只小猫咪还是……
  • 月照霜河

    月照霜河

    一个流浪的故事,一个草根人物,命运多舛,与命运和世界对抗,执着于执念,追求生命终极的史诗。历史跌宕,俗世百态,万邦林立,江湖纷争,除魔卫道,却看主角如何撕开命运的枷锁,挣脱天地的极限,一步步穿过荆棘无数,铸就唯一的传奇。斜月一轮照霜河,天外孤客双袖冷。今缘岂是命注定,恩怨情仇一场梦。只身而去出河梁,潜龙一怒落星辰。诸事了却拂衣去,一人一马笑苍生。
  • 说说那几年

    说说那几年

    我喜欢你已有七年我爱上你不过瞬间你爱不爱我我不知道只愿你能够回头看我一眼哪怕一眼我本不是软脚虾为何兄弟要如此待我在这世界上软弱就要被打那么我就组建自己的势力和你们一决高下
  • 那年围城里

    那年围城里

    他,是家里备受宠爱的大少爷,桀骜不驯,就是他的量身名词。她,是阳晴四姐妹中的老小,单纯可爱,“姐姐们”疼爱到了极致。在这小小的围城里,当受宠的他遇上被疼的她,是魔高一尺,还是道高一丈呢?“这是个低智商的问题,我不给于回答。”“开什么玩笑!只要他在阳晴初中部,就是踩在我们的领域里,你说谁输谁赢?”“我反正是支持老小的。”如此这般,在这被围墙围起得几百亩校园里,他们是这个小小世界的唯一参演者。【已然未然里小夏默千的故事,只是觉得这个名字很好听,就开了故事==】
  • 龙帝焚天祭

    龙帝焚天祭

    这个世界变了——不再是善有善报,恶有恶报了!1000年过去了世界迎来大动乱:李唐皇室复出,天下三分!三大秩序一魔道谁对谁错?墨宇是一个普通的男孩,在这个混乱只能靠力量生存的社会里甚至都无法保护自己,他是被欺负的对象,受偏见的目标。但却莫名其妙的拥有了力量被三秩序之一的——“普雷圣院”选为领袖,从此和伙伴开始了找寻真理的冒险之旅。