当前位置: 首页 > news >正文

网站开发程序员岗位职责网站自适应 常用尺寸

网站开发程序员岗位职责,网站自适应 常用尺寸,组建网站需多少钱,扬州网站建设推广目录 一、什么是HTTPS1、加密解密是什么2、为什么要加密3、常见的加密方式1、对称加密2、非对称加密 二、探究HTTPS如何实现加密1、方案一----只使用对称加密2、方案二----只使用非对称加密3、方案三----双方都使用非对称加密4、方案四----非对称加密 对称加密5、中间人攻击6、… 目录 一、什么是HTTPS1、加密解密是什么2、为什么要加密3、常见的加密方式1、对称加密2、非对称加密 二、探究HTTPS如何实现加密1、方案一----只使用对称加密2、方案二----只使用非对称加密3、方案三----双方都使用非对称加密4、方案四----非对称加密 对称加密5、中间人攻击6、方案五----非对称加密 对称加密 证书认证1.1、CA认证1.2、数据签名1.3、数据摘要和数字指纹1.4、加密过程1.5、查看浏览器的受信任证书发布机构1.6、还会存在中间人攻击吗 三、常见问题1、为什么摘要内容在网络传输的时候一定要加密形成签名?2、为什么签名不直接加密而是要先hash形成摘要?3、如何成为中间人 四、总结 一、什么是HTTPS HTTPS也是一个应用层协议而HTTP协议内容的传输方式是明文的这就导致在传输过程中会出现一些被篡改的情况基于这种情况所以HTTPS就是在HTTP协议的基础上引入了一个加密层那么什么是加密解密呢 1、加密解密是什么 简单点说加密就是把明文进行一系列的变换生成密文。 解密就是把密文再进行一系列变换还原成明文。 而在这个加密解密过程中往往会有一个或多个中间数据辅助这个过程而这样的数据就叫密钥。 加密解密过程就像我们用钥匙锁门一样插进钥匙空逆时针转一下就是加密过程顺时针转一下就是解密过程而钥匙上的齿轮就是密钥 加密解密到如今已经发展成⼀个独立的学科密码学而密码学的奠基人也正是计算机科学的祖师爷之⼀艾伦·麦席森·图灵 2、为什么要加密 举个例子我们打开电脑会弹出各种各样莫名其妙的烦人弹窗广告而我们去点击关闭时就会给我们弹到其他页面有时会给我们下载一些不需要的东西。 由于我们通过网络传输的任何的数据包都会经过运营商的网络设备(路由器、交换机等)那么运营商的网络设备就可以解析出你传输的数据内容并进行篡改。这就是运营商劫持事件。 我们点击关闭按钮其实就是在给服务器发送一个HTTP请求获取到的HTTP响应其实就包含了该APP的下载链接运营商劫持后就会发现这个请求是要下载的对应APP那么就会自动的把用户的响应给篡改成对应APP的下载地址了。 所以因为HTTP的内容是明文传输的明文数据会经过路由器、wifi热点通信服务运营商、代理服务器等多个物理节点如果在传输过程中被劫持那么传输的内容则完全暴露了。劫持者还可以对篡改传输的信息且不被双方察觉这就是中间人攻击所以我们就需要对信息进行加密。 当然不仅运营商可以进行劫持其他黑客或不法分子也是可以用同样的手段进行劫持信息来窃取用户的隐私或者篡改内容甚至窃取用户的支付宝、微信等支付密码所以明文传输是比较危险的。 3、常见的加密方式 1、对称加密 采用单密钥的加密方法用同一个密钥对信息进- 行加密和解密这种加密方法称为对称加密也称为单密钥加密。特征加密和解密所用的密钥都是相同的。特点算法公开、计算量小、加密速度快、加密效率高。常见对称加密算法DES、3DES、AES等 对称加密其实就是通过同⼀个密钥把明文加密成密文并且也能把密文解密成明文。 举个例子 ⼀个简单的对称加密按位异或 假设明文 a 1234密钥 key 8888 则加密 a ^ key 得到的密文 b 为 9834 然后针对密⽂ 9834 再次进行运算 b ^ key得到的就是原来的明文 1234。 当然按位异或只是最简单的对称加密HTTPS中并不是使⽤按位异或。 2、非对称加密 需要两个密钥来进行加密和解密这两个是公开密钥简称公钥和私有密钥简称私钥特点算法强度复杂、安全性依赖于算法与密钥但是由于其算法复杂而使得加密解密速度没有对称加密解密的速度快。常见非对称加密算法RSA、DSA等 非对称加密要用到两个密钥⼀个叫做公钥⼀个叫做私钥。而公钥和私钥是配对的最大的缺点就是运算速度非常慢比对称加密要慢很多。 通过公钥对明文加密变成密文也可以通过私钥对明文加密变成密文通过私钥对密文解密变成明文也可以通过公钥对密文解密变成明文 举个例子 A要给B一些重要的文件但是B可能不在于是A和B就提前做了一个约定 B说我桌子上有一个盒子我给你⼀把锁你把文件放盒子里用锁锁上然后我回头拿着钥匙来开锁取文件。 在这个场景中这把锁就相当于公钥钥匙就是私钥公钥给谁都可以不用怕被泄露但是私钥只有B自己持有持有私钥的人才能解密。 二、探究HTTPS如何实现加密 既然要保证数据安全就需要对数据进行加密所以网络传输中不再直接传输明文了而是加密之后的密文。 加密的方式有很多但是整体可以分成两大类对称加密和非对称加密。 1、方案一----只使用对称加密 如果通信双方都各自持有同⼀个密钥C且没有别人知道这两方的通信安全当然是可以被保证的除非密钥被破解 引入对称加密之后即使数据被截获由于黑客不知道密钥是啥是什么因此就无法进行解密也就不知道请求的真实内容是什么了。 但是如果服务器同⼀时刻是给很多客户端提供服务的呢。 这么多客户端每个人用的秘钥都必须是不同的因为如果是相同那密钥就太容易扩散和泄密了黑客就也能拿到密钥了因此服务器就需要维护每个客户端和每个密钥之间的关联关系这也是个很麻烦的事情 比较理想的做法就是能在客户端和服务器建立连接的时候双方协商确定这次的密钥是什么 但是如果直接把密钥明文传输那么黑客也就能获得密钥了此时后续的加密操作就形同虚设了。因此密钥的传输也必须加密传输。 但是要想对密钥进行对称加密就仍然需要先协商确定一个密钥的密钥这就成了先有鸡还是先有蛋的问题了此时密钥的传输再用对称加密就行不通了。 2、方案二----只使用非对称加密 鉴于非对称加密的机制如果服务器先把公钥以明文方式传输给浏览器之后浏览器向服务器传数据前都先用这个公钥加密好再传从客户端到服务器信道似乎是安全的因为只有服务器有相应的私钥能解开公钥加密的数据。 但是服务器到浏览器的这条路怎么保障安全呢 如果服务器用它的私钥加密数据传给浏览器那么浏览器用公钥可以解密它而这个公钥是一开始通过明文传输给浏览器的若这个公钥被中间人劫持到了那他也能用该公钥解密服务器传来的信息了。 3、方案三----双方都使用非对称加密 服务端拥有公钥S与对应的私钥S’客户端拥有公钥C与对应的私钥C’客户端和服务端交换公钥客户端给服务端发信息先用S对数据加密再发送只能由服务器解密因为只有服务器有私钥S’服务端给客户端发信息先用C对数据加密在发送只能由客户端解密因为只有客户端有私钥C’ 这样貌似也行啊但是 效率太低依旧有安全问题 4、方案四----非对称加密 对称加密 先解决效率问题 服务端具有非对称公钥S和私钥S’客户端发起https请求获取服务端公钥S客户端在本地生成对称密钥C通过公钥S加密发送给服务器由于中间的网络设备没有私钥即使截获了数据也无法还原出内部的原文也就无法获取到对称密钥但是真的不能获取吗服务器通过私钥S’解密还原出客户端发送的对称密钥C并且使用这个对称密钥加密给客户端返回的响应数据。后续客户端和服务器的通信都只用对称加密即可由于该密钥只有客户端和服务器两个主机知道其他主机/设备不知道密钥即使截获数据也没有意义。 由于对称加密的效率比非对称加密高很多因此只是在开始阶段协商密钥的时候使用非对称加密后续的传输仍然使用对称加密。 但是依然有安全问题方案2方案3方案4都存在一个问题如果最开始中间人就已经开始攻击了呢 5、中间人攻击 在方案2、3、4中客户端获取到公钥S之后对客户端形成的对称秘钥C用服务端给客户端的公钥S进行加密中间人即使窃取到了数据此时中间人确实无法解出客户端形成的密钥C因为只有服务器有私钥S’。 但是中间人的攻击如果在最开始握手协商的时候就进行了那就不一定了假设hacker已经成功成为中间人 服务器具有非对称加密算法的公钥S私钥S’中间人具有非对称加密算法的公钥M私钥M’客户端向服务器发起请求服务器明文传送公钥S给客户端中间人劫持数据报文提取公钥S并保存好然后将被劫持报文中的公钥S替换成为自己的公钥M并将伪造报文发给客户端客户端收到报文提取公钥M此时自己当然不知道公钥被更换过了自己形成对称秘钥C用公钥M加密对称秘钥C形成报文发送给服务器中间人劫持后直接用自己的私钥M’进行解密得到对称密钥钥C再用曾经保存的服务端公钥S加密后将报文推送给服务器服务器拿到报文用自己的私钥S’解密得到对称密钥C双方开始采用对称密钥C进行对称加密进行通信。但是一切都在中间人的掌握中劫持数据进行窃听甚至修改都是可以的 6、方案五----非对称加密 对称加密 证书认证 1.1、CA认证 服务端在使用HTTPS前需要向CA机构申领一份数字证书数字证书里含有证书申请者信息、公钥信息等。服务器把证书传输给浏览器浏览器从证书里获取公钥就行了证书就如身份证证明服务端公钥的权威性 这个证书也可以理解成是⼀个结构化的字符串里面包含了以下信息证书发布机构、证书有效期、公钥、证书所有者、签名等等 需要注意的是申请证书的时候需要在特定平台生成查会同时生成一对密钥对即公钥和私钥。这对密钥对就是用来在网络通信中进行明文加密以及数字签名的。其中公钥会随着CSR文件一起发给CA进行权威认证私钥由服务端自己保留用来后续进行通信其主要就是用来交换对称秘钥 1.2、数据签名 签名的形成是基于非对称加密算法的注意目前暂时和https没有关系不要和https中的公钥私钥搞混了 当服务端申请CA证书的时候CA机构会对该服务端进行审核并专门为该网站形成数字签名过程如下 CA机构拥有非对称加密的私钥A和公钥A’CA机构对服务端申请的证书明文数据进行hash形成数据摘要然后对数据摘要用CA私钥A’加密得到数字签名S 服务端申请的证书明文和数字签名S共同组成了数字证书这样一份数字证书就可以颁发给服务端了 CA机构 只能用CA的私钥形成签名CA私钥只有CA自己知道世界上只有CA能够完成签名的过程因为CA是权威机构为了保证合法性一般OS和浏览器内部在出厂下载的时候就已经内置了CA的公钥 1.3、数据摘要和数字指纹 数据摘要其基本原理是利用单向散列函数(Hash函数)对信息进行运算生成一串固定长度的数字摘要。数字指纹并不是一种加密机制,但可以用来判断数据有没有被窜改。摘要常见算法MD5、SHA1、SHA256、SHA512等算法把无限的映射成有限因此可能会有碰撞即两个不同的信息算出的摘要相同但是概率非常低摘要特征和加密算法的区别是摘要严格意义不是加密因为没有解密只不过从摘要很难反推原信息通常用来进行数据对比。 1.4、加密过程 在客户端和服务器刚⼀建里连接的时候服务器给客户端返回一个证书证书包含了之前服务端的公钥也包含了网站的身份信息 客户端进行认证 当客户端获取到这个证书之后会对证书进行校验防止证书是伪造的 判定证书的有效期是否过期判定证书的发布机构是否受信任操作系统中已内置的受信任的证书发布机构验证证书是否被篡改从系统中拿到该证书发布机构的公钥对签名解密得到⼀个hash值(称为数据摘要)设为hash1然后计算整个证书的hash值设为hash2对比hash1和hash2是否相等如果相等则说明证书是没有被篡改过的 1.5、查看浏览器的受信任证书发布机构 选择设置搜索管理证书如果没有在隐私设置和安全性-安全里面找找即可看到以下界面 1.6、还会存在中间人攻击吗 中间人有没有可能篡改该证书呢 中间人篡改了证书的明文但是由于他没有CA机构的私钥所以hash之后无法用私钥加密形成签名那么也就没法办法对篡改后的证书形成匹配的签名如果强行篡改客户端收到该证书后会发现明文和签名解密后的值不一致则说明证书已被篡改证书不可信从而终止向服务器传输信息防止信息泄露给中间人中间人可能掉包整个证书吗 因为中间人没有CA私钥所以无法制作假的证书所以中间人只能向CA机构申请真证书然后用自己申请的证书进行掉包这个确实能做到证书的整体掉包但是证书明文中包含了域名等服务端认证信息如果整体掉包客户端依旧能够识别出来。永远记住中间人没有CA私钥所以对任何证书都无法进行合法修改包括自己的 三、常见问题 1、为什么摘要内容在网络传输的时候一定要加密形成签名? 常见的摘要算法有MD5和SHA系列 以MD5为例我们不需要研究具体的计算签名的过程只需要了解MD5的特点 定长无论多长的字符串计算出来的MD5值都是固定长度的(16字节版本或者32字节版本)分散原字符串只要改变⼀点点最终得到的MD5值都会有很大的差别不可逆通过原字符串生成MD5很容易但是通过MD5还原成原字符串理论上是不可能的 正因为MD5有这样的特性我们可以认为如果两个字符串的MD5值相同则认为这两个字符串相同 假设我们的证书只是⼀个简单的字符串hello对这个字符串计算hash值(比如MD5)结果为BC4B2A76B9719D91 如果hello中有任意的字符被篡改了比如变成了hella那么计算的MD5值就会变化很大BDBD6F9CF51F2FD8 然后我们可以把这个字符串hello的哈希值BC4B2A76B9719D91从服务器返回给客户端此时客户端就只要计算hello的哈希值看看是不是BC4B2A76B9719D91即可。 但是如果黑客把hello篡改了同时也把哈希值重新计算下客户端就分辨不出来了 所以被传输的哈希值不能传输明文需要传输密文 所以对证书明文(这里就是“hello”)hash形成散列摘要然后CA使用自己的私钥加密形成签名将hello和加密的签名合起来形成CA证书颁发给服务端当客户端请求的时候就发送给客户端中间人截获了因为没有CA私钥就无法更改或者整体掉包就能安全的证明证书的合法性。最后客户端通过操作系统里已经存了的证书发布机构的公钥进行解密还原出原始的哈希值再进行校验。 2、为什么签名不直接加密而是要先hash形成摘要? 缩小签名密文的长度加快数字签名和验证签名的运算速度 3、如何成为中间人 ARP欺骗在局域网中hacker经过收到ARP的Request广播包能够偷听到其它节点的IP和MAC地址。例如黑客收到两个主机A和B的地址告诉B(受害者)自己是A使得B在发送给A的数据包都被黑客截取ICMP攻击由于ICMP协议中有重定向的报文类型那么我们就可以伪造一个ICMP信息然后发送给局域网中的客户端并伪装自己是一个更好的路由通路。从而导致目标所有的上网流量都会发送到我们指定的接口上达到和ARP欺骗同样的效果假wifi、假网站等 四、总结 完整流程 HTTPS工作过程中涉及到的密钥有三组 第一组(非对称加密)用于校验证书是否被篡改服务器持有私钥(私钥在形成CSR文件与申请证书时获得)客户端持有公钥(操作系统包含了可信任的CA认证机构有哪些同时持有对应的公钥)服务器在收到客户端请求时返回携带签名的证书客户端通过这个公钥进行证书验证保证证书的合法性进⼀步保证证书中携带的服务端公钥权威性。第二组(非对称加密)用于协商生成对称加密的密钥客户端用收到的CA证书中的公钥(是可被信任的)给随机生成的对称加密的密钥加密传输给服务器服务器通过私钥解密获取到对称加密密钥第三组(对称加密)客户端和服务器后续传输的数据都通过这个对称密钥进行加密和解密 第一组非对称加密的密钥是为了让客户端拿到第二组非对称加密的公钥 第二组非对称加密的密钥是为了让客户端把这个对称密钥传给服务器 其实一切的关键都是围绕这个对称加密的密钥其他的机制都是辅助这个密钥工作的
http://www.dnsts.com.cn/news/23837.html

相关文章:

  • wordpress 文章互链连云港网站推广优化
  • 天津做网站优化公共资源交易中心职能
  • 营销型网站郭老师案例分享做网站要学那些东西
  • 网站后台模板 免费详情页设计风格
  • 网站建设多少带宽WordPress短码生成器
  • 架设网站费用重庆大渡口营销型网站建设公司哪家好
  • 怎样免费给自己的公司做网站公司网站制作仿站
  • 网站服务器多少钱网站描述作用
  • 成都seo网站建设百度后台管理
  • 自助建子站wordpress 质感主题
  • 滨海做网站的公司消防电气火灾监控系统网站开发
  • 网站建设各部门职责策划信息化设计公司排名
  • 怎么建个人网站如何破解网站后台管理
  • 58同城网站建设案例wordpress数据库在哪
  • 专门做折扣的网站有哪些网页制作背景图代码
  • 珠海企业网站搭建制作wordpress建两个网站
  • 网站建设情况的自查报告山东东营市旅游景点大全
  • 黄埔移动网站建设电商平台推广员是做什么的
  • 惠州制作网站软件网站开发工作协议书范本
  • 市政建设招标网站有哪些网上购物网站建设的实训报告
  • 网站虚拟主持人网站开发中都引用什么文献
  • 怎样建立一个公司网站DW做旅游网站模板
  • 网站关键词优化建议网页制作与设计怎么设置圆角
  • 济南网站优化推广公司电话东莞免费建站模板
  • 网站开发需要注意的问题编程软件python下载
  • 网站开发工程师的职位网页升级访问最新区域每天自动更新
  • 电子商务网站的作用wordpress全站转移
  • 佛山网站快速优化排名android开发环境
  • 外贸论坛网站有哪些wordpress 添加qq
  • 设计什么网站简单深圳网站的优化公司