网络协议 概念

网络协议 概念

## 概念

Hypertext Transfer Protocol, 超文本传输(转移)协议,是客户端和服务端传输文本制定的协议。构建WWW的具体的三项技术如下:

WWW: world wide web, 万维网
    
    – HTML: Hypertext Markup Language, 超文本标记语言
    – HTTP: Hypertext Transfer Protocol, 超文本传输(转移)协议 (HTTP是TCP/IP的应用层协议)
    – URL: Uniform Resource Locator, 统一资源定位符号

> URI: Uniform Resource Identitier, 统一资源标示符号,URL是URI的子集

## TCP/IP

“`
    应用层(http/https/websocket/ftp…) => 定义:文本传输协议
      |
    传输层(tcp/udp) => 定义:端口
      |
    网络层(ip) => 定义:IP
      |
    链路层(mac&数据包) => 定义:数据包,MAC地址
      |
    实体层(光缆/电缆/交换机/路由/终端…) => 定义:物理
“`

TCP/IP:

– 解释一:分别代表tcp协议和ip协议
– 解释二:如果按照网络五层架构,TCP/IP代表除了应用层其他层所有协议簇的统称

TCP/IP connect: TCP/IP的三次握手:
“`
          标有syn的数据包
          ————->
          标有syn/ack的数据包
  client  <————-  server
          标有ack的数据包
          ————–>
“`

TCP/IP finish: TCP/IP的四次握手:
“`
                          fin
                    <————-
                          ack
client(或server)    ————-> server(或client)
                          fin
                    ————->
                          ack
                    <————-
“`

## HTTP 报文

HTTP 报文由三部分组成:
– Start Line
– Headers
– Entity Body

HTTP 报文分为两类:
– 请求报文
– 响应报文

### 请求报文Start Line

语法 : <方法> <请求URL> <版本>

#### HTTP Method

+ get: 获取资源,不携带http body,支持查询参数,大小2KB
+ post: 传输资源,http body, 大小默认8M,1000个input variable
+ put: 传输资源,http body,资源更新
+ delete: 删除资源,不携带http body
+ patch: 传输资源,http body,存在的资源局部更新
+ head: 获取http header,不携带http body
+ options: 获取支持的method,不携带http body
+ trace: 追踪,返回请求回环信息,不携带http body
+ connect: 建立隧道通信

### 响应报文Start Line

语法 : <方法> <状态码> <原因短语>

#### HTTP Status Code

+ 200: ok
+ 301: 永久重定向
+ 302: 临时重定向
+ 303: 临时重定向,要求用get请求资源
+ 304: not modified, 返回缓存,和重定向无关
+ 307: 临时重定向,严格不从post到get
+ 400: 参数错误
+ 401: 未通过http认证
+ 403: forbidden,未授权
+ 404: not found,不存在资源
+ 500: internet server error,代码错误
+ 502: bad gateway,fastcgi返回的内容web server不明白
+ 503: service unavailable,服务不可用
+ 504: gateway timeout,fastcgi响应超时

### HTTP Header Fields

常见通用头部

+ Cache-Control:
  – no-cache: 不缓存过期的缓存
  – no-store: 不缓存
+ Pragma: no-cache, 不使用缓存,http1.1前的历史字段
+ Connection:
  – 控制不在转发给代理首部不字段
  – Keep-Alive/Close: 持久连接
+ Date: 创建http报文的日期

常见请求头

+ Accept: 可以处理的媒体类型和优先级
+ Host: 目标主机域名
+ Referer: 请求从哪发起的原始资源URI
+ User-Agent: 创建请求的用户代理名称
+ Cookie: cookie信息  

常见响应头

+ Location: 重定向地址
+ Server: 被请求的服务web server的信息
+ Set-Cookie: 要设置的cookie信息
  – NAME: 要设置的键值对
  – expires: cookie过期时间
  – path: 指定发送cookie的目录
  – domain: 指定发送cookie的域名
  – Secure: 指定之后只有https下才发送cookie
  – HostOnly: 指定之后javascript无法读取cookie
+ Keep-Alive:

HTTP协议初期每次连接结束后都会断开TCP连接,之后HEADER的connection字段定义Keep-Alive(HTTP 1.1 默认 持久连接),代表如果连接双方如果没有一方主动断开都不会断开TCP连接,减少了每次建立HTTP连接时进行TCP连接的消耗。

## Cookie/Session

+ Cookie: 工作机制是用户识别和状态管理,服务端为了管理用户的状态会通过客户端,把一些临时的数据写入到设备中Set-Cookie,当用户访问服务的时候,服务可以通过通信的方式取回之前存放的cookie。
+ Session: 由于http是无状态的,请求之间无法维系上下文,所以就出现了session作为会话控制,服务端存放用户的会话信息。

## HTTPs

概念:在http协议上增加了ssl(secure socket layer)层。

“`
    SSL层
      |
    应用层
      |
    传输层
      |
    网络层
      |
    链路层
      |
    实体层
“`

HTTPS 认证流程
“`

                              发起请求
                     —————————>  server
                              下发证书
                      <—————————   server
                      证书数字签名(用证书机构公钥加密)
                     —————————>  证书机构
                          证书数字签名验证通过
client(内置证书机构证书) <—————————   证书机构
                      公钥加密随机密码串(未来的共享秘钥)
                     —————————>  server私钥解密(非对称加密)
                        SSL协议结束 HTTP协议开始
                      <—————————   server(对称加密)
                            共享秘钥加密 HTTP
                     —————————>  server(对称加密)
“`

+ 核对证书证书: 证书机构的公开秘钥验证证书的数字签名
+ 公开密钥加密建立连接:非对称加密
+ 共享密钥加密

## Websocket

+ 基于http协议建立连接,header的upgrade字段转化协议为websocket
+ 全双工通信,客户端建立连接

## HTTP2

+ 多路复用:多个请求共享一个tcp连接
+ 全双工通信
+ 必须https://
+ 头部压缩
+ 二进制传输

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/113826.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • JS-jquery 获取当前点击的对象

    JS-jquery 获取当前点击的对象

    2021年10月31日
    39
  • 图片如何保存在服务器(PHP生成一张图片并保存到服务器)

    自己没有服务器,但是又想把自己的照片放到网上怎么办?今天在写博客的时候灵机一现,这个平台编辑文章的时候不就可以上传图片吗!而且还有图片的链接,哈哈!也算是个小彩蛋吧~~…

    2022年4月14日
    109
  • c# restsharp官网_hbase shell put

    c# restsharp官网_hbase shell putusingSystem;usingSystem.Net.Http;usingSystem.Threading.Tasks;usingSystem.Collections.Generic;usingNewtonsoft.Json;usingSystem.Net;usingSystem.IO;usingSystem.Text;usingRestSharp;namespaceHttpClientQuery{classPageInfo{publicintstar

    2025年10月9日
    3
  • 惠普电脑有电脑管家吗_电脑管家检测硬件就蓝屏

    惠普电脑有电脑管家吗_电脑管家检测硬件就蓝屏据海外媒体WindowsLatest的报道,大量的Windows10用户的设备最近频繁出现蓝屏,多家硬件设备厂商均中招。联想电脑管家安全团队已证实暂不涉及联想设备的国内用户。同时提醒广大国内用户,暂停近期微软发布的任何更新业务(包括暂停通过Vantage应用程序进行BIOS更新),等待微软官方给出修复补丁。据悉该蓝屏问题是由于近期的一次更新造成,蓝屏(BSOD)错误将会阻止windows10设备的…

    2022年8月13日
    11
  • 舆情监控系统python开源_舆情监测系统开源

    舆情监控系统python开源_舆情监测系统开源互联网已成为思想文化信息的集散地和社会舆论的放大器。截至2009年6月30日,我国网民数量达到3.38亿人,网民规模已稳居世界第一位,互联网的影响力也日益提升,网络舆论已成为不可小觑的强大社会力量。近年来,网络热点事件频发,其大背景主要有两方面:一是我国社会处于转型期,涌现出一些新矛盾和新问题,如贫富悬殊、官员腐败、传统价值观受冲击等;二是随着互联网技术的迅速发展,越来越多的人上网获取新闻信息,发…

    2025年11月25日
    2
  • [已解决]踩过的坑之mysql连接报“Communications link failure”错误

    [已解决]踩过的坑之mysql连接报“Communications link failure”错误目录前言第一种方法:第二种方法第三种方法(适用于项目和数据库在同一台服务器)第四种方法第五种方法(项目和数据库不在同一台服务器)总结前言先给大家简述一下我的坑吧,(我用的是mysql,至于oracle有没有这样的问题,有心的小伙伴们可以测试一下哈),在自己做个javaweb测试项目的时候,因为买的是云服务器,所以数据库连接的是用ip地址,用IDE开发好…

    2022年5月18日
    56

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号