androidssl证书交换流程.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
androidssl证书交换流程

Android SSL证书交换流程 创建https链接 浏览器在显示页面之前需要建立http/https链接,然后利用http/https链接去下载html文件以及html文件中嵌入的jpeg、gif等格式图片。如果资源的url具有的前缀是“http://”,那么需要建立http链接。如果资源的url具有的前缀是“https://”,那么需要建立https链接。双向业务需要利用https协议来发送加密数据。 Android webkit不关心获取资源的协议类型,只需要调用Network. requestURL接口即可发送请求。Network.requestURL首先创建Request对象、RequestHandle对象、RequestQueue对象,Connection对象,然后调用RequestHcessRequest就可以完成请求。在上述过程中,NetWork并不知道Connection的类型。与https链接建立过程有关的类以及它们之间的关系可以参考下图: 图1 类图 类之间的调用顺序图如下: 图2 顺序图 经过分析,建立https链接的流程不需要修改。 SSL握手与验证 https协议利用SSL协议验证通信双方(客户端、服务器端)的身份、协商加密算法与密钥。Android中HttpsConnection类实现了https协议。SSLSocket相关类实现了SSL协议。HttpsConnection只需通过SocketFactory以及Socket提供的抽象接口就可以启动SSL握手过程。 主要由SSLSocket、OpenSSLSocketImpl、SSLParameters、SSLSession、OpenSSLSocketFactoryImpl、OpenSSLSessionImpl、SSLSessionContext实现SSL协议。HttpsConnection使用系统提供的默认工厂SSLSocketFactoryImpl创建OpenSSLSocketImpl。OpenSSLSocketImpl通过JNI调用openSSL库提供的api进行握手。注意握手信息是在SocketImpl对象上传输的。SSLSession类封装了SSL会话信息,它存储了SSL握手的结果。最后SSLSessionContext相当与SSLSession的缓存池。这些类之间的关系如下图所示: 图3 SSLSocket类图 类之间的调用顺序如下: 图4 SSLSocket 时序图 这里需要额外说明的是:在执行nativeconnect函数时,已经在openSSL库中执行了握手过程。但openSSL库中不会进行任何验证,因为验证模式被设置为SSL_VERIFY_NONE。因此,Android中身份验证是由checkServerTrusted函数实现的。 经过分析,openSSL库可以参照RocME_3.0的openSSL模块来修改。另外额外的工作量是,需要将底层的证书正确的映射为X509Certificate对象。 数字证书、公钥、密钥 Android系统使用openSSL库来交换证书、协商加密算法,但认证服务器段身份并非由openSSL库完成。Android系统将自己的证书、私钥存储在密钥仓库中。在进行openSSL握手之前,将私钥以及证书放入SSL_CTX变量中。握手结束后,Android系统从SSLSession中取出服务器的证书,利用可信密钥仓库来检验该证书是否可信。相关类以及类之间的关系如下图所示: 图 图 5 cetificate 类图 在集成BNSAS时,需要将TSM模块提供的密钥以及证书转存储到Android的密钥仓库中。这样可以不修改Android框架,让服务器端验证终端的身份。另外,还需要将TSM模块提供的验签算法加入到TrustManager认证体系中。

文档评论(0)

xjj2017 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档