zoukankan      html  css  js  c++  java
  • http和https的区别

    http和https的区别;
    HTTPS是HTTP协议的安全版本,HTTP协议的数据传输是明文的,是不安全的,HTTPS使用了SSL/TLS协议进行了加密处理。
    http和https使用连接方式不同,默认端口也不一样,http是80,https是443





    1.HTTP协议是什么?
    HTTP协议是超文本传输协议的缩写,英文是Hyper Text Transfer Protocol。它是从WEB服务器传输超文本标记语言(HTML)到本地浏览器的传送协议。设计HTTP最初的目的是为了提供一种发布和接收HTML页面的方法。HTPP有多个版本,目前广泛使用的是HTTP/1.1版本。
    2.HTTP原理
    HTTP是一个基于TCP/IP通信协议来传递数据的协议,传输的数据类型为HTML 文件,、图片文件, 查询结果等。HTTP协议一般用于B/S架构()。浏览器作为HTTP客户端通过URL向HTTP服务端即WEB服务器发送所有请求。
    3.HTTP特点
    http协议支持客户端/服务端模式,也是一种请求/响应模式的协议。
    简单快速:客户向服务器请求服务时,只需传送请求方法和路径。请求方法常用的有GET、HEAD、POST。
    灵活:HTTP允许传输任意类型的数据对象。传输的类型由Content-Type加以标记。
    无连接:限制每次连接只处理一个请求。服务器处理完请求,并收到客户的应答后,即断开连接,但是却不利于客户端与服务器保持会话连接,为了弥补这种不足,产生了两项记录http状态的技术,一个叫做Cookie,一个叫做Session。
    无状态:无状态是指协议对于事务处理没有记忆,后续处理需要前面的信息,则必须重传。
    4.URI和URL的区别
    HTTP使用统一资源标识符(Uniform Resource Identifiers, URI)来传输数据和建立连接。
    URI:Uniform Resource Identifier 统一资源标识符
    URL:Uniform Resource Location 统一资源定位符
    URI 是用来标示 一个具体的资源的,我们可以通过 URI 知道一个资源是什么。
    URL 则是用来定位具体的资源的,标示了一个具体的资源位置。互联网上的每个文件都有一个唯一的URL。
    5.HTTP报文组成请求报文构成
    请求行:包括请求方法、URL、协议/版本
    请求头(Request Header)
    请求正文
    响应报文构成
    状态行
    响应头
    响应正文
    6.常见请求方法
    GET:请求指定的页面信息,并返回实体主体。
    POST:向指定资源提交数据进行处理请求(例如提交表单或者上传文件)。数据被包含在请求体中。POST请求可能会导致新的资源的建立和/或已有资源的修改。
    HEAD:类似于get请求,只不过返回的响应中没有具体的内容,用于获取报头
    PUT:从客户端向服务器传送的数据取代指定的文档的内容。
    DELETE:请求服务器删除指定的页面。
    7.为什么要用https?
    实际使用中,绝大说的网站现在都采用的是https协议,这也是未来互联网发展的趋势。下面是通过wireshark抓取的一个博客网站的登录请求过程。
    一般http中存在如下问题:
    请求信息明文传输,容易被窃听截取。
    数据的完整性未校验,容易被篡改
    没有验证对方身份,存在冒充危险
    8.什么是HTTPS?
    为了解决上述HTTP存在的问题,就用到了HTTPS。
    HTTPS 协议(HyperText Transfer Protocol over Secure Socket Layer):一般理解为HTTP+SSL/TLS,通过 SSL证书来验证服务器的身份,并为浏览器和服务器之间的通信进行加密。
    那么SSL又是什么?
    SSL(Secure Socket Layer,安全套接字层):1994年为 Netscape 所研发,SSL 协议位于 TCP/IP 协议与各种应用层协议之间,为数据通讯提供安全支持。TLS(Transport Layer Security,传输层安全):其前身是 SSL,它最初的几个版本(SSL 1.0、SSL 2.0、SSL 3.0)由网景公司开发,1999年从 3.1 开始被 IETF 标准化并改名,发展至今已经有 TLS 1.0、TLS 1.1、TLS 1.2 三个版本。SSL3.0和TLS1.0由于存在安全漏洞,已经很少被使用到。TLS 1.3 改动会比较大,目前还在草案阶段,目前使用最广泛的是TLS 1.1、TLS 1.2。
    9.HTTPS的缺点
    HTTPS协议多次握手,导致页面的加载时间延长近50%;
    HTTPS连接缓存不如HTTP高效,会增加数据开销和功耗;
    申请SSL证书需要钱,功能越强大的证书费用越高。
    SSL涉及到的安全算法会消耗 CPU 资源,对服务器资源消耗较大。

  • 相关阅读:
    [TJOI2018]教科书般的亵渎
    luogu P4781 【模板】拉格朗日插值
    [SDOI2010]捉迷藏
    [CQOI2016]K远点对
    BZOJ4066 简单题
    [国家集训队]JZPFAR
    Understanding User and Kernel Mode
    Linux下如何查看系统启动时间和运行时间以及安装时间
    CentOS Linux搭建独立SVN Server全套流程(修改svn仓库地址、服务启动等)
    linux下获取占用CPU资源最多的10个进程,可以使用如下命令组合:
  • 原文地址:https://www.cnblogs.com/Sxp1111/p/14062853.html
Copyright © 2011-2022 走看看