URL(Unifrom Resource Locator)简述

相对URL 从当前页面(同一个站点内或同一个文章内引用)

绝对URL 从当前页面或其他页面跳转而来(跨站引用)

HTTPD版本<0.9文本><1.0,method,mime,弱缓存><1.1持久连接><2.0,mime,spdy,缓存,method>

HTTPD特性:无状态、文本编码协议<telnet, curl, enlinks>

追踪用户来源的机制:cookie(重cookie,轻cookie),session

Cookie分类

Cookie工作机制: 随机数惟一标识用户

轻cookie应用: 数据结构保存cookie与session的映射

100信息

200 OK 成功

301 Moved Permantly 永久 302 Found 临时 304 Not Modified 条件

401 WWW-Authenticate 质询认证   403 Forbidden 没有权限访问  404 Not Found 没有资源

500 Internal Server Error 服务内部错误    502 Bad Gateway 错误网关

一、URL 

Uniform Resource Locator 标识每个资源的位置 URL是URI的子集

相对URL:相对当前页面的URL,(相对路径:由当前工作目录起始的路径)

绝对URL:用于跨站引用或当前页面,(绝对路径:由/起始的路径)

二、HTTPD版本 

2.1、HTTPD特性

  • http stateless 无状态 服务器无法持续追踪访问者来源
  • 文本编码协议

2.2、追踪用户来源的机制

  动态站点中用来追踪并保存用户浏览行为的或访问行为的重要机制:Cookie ,session

2.2.1、Cookie工作方式(相当于第一次访问某服务器时候,此service发给client的令牌)

  二次通信:

  服务器 接收随机数(令牌) <-- 客户端  将访问的服务器首次所发的令牌发给服务器,用于标明自己的身份

2.2.2、Cookie分类

  重cookie:有可能会泄露用户隐私

  轻cookie:只记录少量的信息

      免费的杀毒软件,可以获取磁盘底层的信息最高权限,有的放矢的投放广告

2.2.3、Session:<轻cookie:减小隐私信息丢失的可能性>,在服务器端在进程内存中维护Session

2.3、HTTP事务

  一次httpd请求request对应一次响应respone,即为事务

  事务元数据:(起始行+headers)

  实体:entity-body部分

HTTP请求响应报文详解

2.3.1、请求报文语法

<method> <requeset-url> <version>    请求报文http首部---请求行
<header>                 首部
换行1
换行2
<entity-body> 请求的主体内容

2.3.2、响应报文语法

<version> <status> <reason-phrase>;响应的原因
<header>
换行1
换行2
<entity-body>

2.3.3、method 请求方法,标明客户端希望服务器端对资源执行的动作(客户端告诉服务器做什么)

  

 POST 向服务器发送要处理的数据,请求实体不为空  (危险)

 PUT  将请求的主体部分存储在服务器上,请求实体不为空 (非常危险)

 DELETE 请求删除服务器上,通过URL指定的文档 (更危险)

2.3.4、status code 服务器告诉客户端结果   统一三位数字,原因短语---标记请求过程中所发生的情况

常用的状态码:

  200 :成功,请求的所有数据通过响应报文的entity-body部分发送: OK

  :请求的URL指向的资源已经被删除;但在响应报文中通过首部Location指明了资源现在所处的新位置:Moved Permanently

  :与301相似,但是在响应报文中通过Location指明资源现在所处临时新位置;Found

  304:客户端发生了条件式请求,但服务器上的资源未曾发生改变,则通过响应此响应状态码通知客户端:Not Modified

  401:需要输入账号和密码认证方能访问资源:Unauthorized

  :请求被禁止:Forbidden

  :服务器无法找到客户端请求的资源:Not Found

  :服务器内部错误:Internal Server Error

  :代理服务器从后端服务器收到一条伪响应 :Bad Gateway

2.3.5、reason-phrase   原因短语 状态码标记的状态简要描述

2.3.6、 headers 首部------用来标记请求或响应的属性

headers 请求和响应首部: 标记请求或响应的属性 , 事务交换的元数据信息

负载均衡调度时,可以根据首部调度

1、首部可以有多个

2、首部的格式:Directive: value

      每个请求或响应报文可包含任意个首部;每个首部都有首部名称,后面跟一个冒号,而后跟上一个可选空格,接着是一个值;

首部的分类:

  • 通用首部:(既可以用在请求报文或者响应报文首部中)

    • Date :报文的创建时间
    • Connection:表示是否需要持久连接状态,如http1.1默认进行keep-alive,close
    • Via :显示报文经过的中间节点
    • Transfer-Encoding:规定了传输报文主体时采用的编码方式
    • Cache-Control : 控制缓存
      • no-cache:先发送请求,与服务器确认该资源是否被更改,如果未被更改,则使用缓存。
      • no-store:不允许缓存,每次都要去服务器上,下载完整的响应。
      • public:缓存所有的响应(提高了响应速度,但是对存储空间的利用率很低)
      • private:只为单个用户缓存,不允许任何中继进行缓存(比如CDN(分发网络)就不能缓存这种规定下的响应)
      • max-age: 表示当前请求开始,该响应在多久内能被缓存和重用。例如:max-age=60表示响应可以再缓存和重用 60 秒。
    • Pragma :兼容HTTP/1.0或HTTP/1.1
  • 请求首部(自己可接受的特性)
    • Accept :通知服务器能自己可接受的媒体类型
    • Accept-Charset : 接受字符集类型
    • Accept-Encoding :接受哪种编码压缩格式,如:gzip, deflate, br
    • Accept-Language:接受的语言
    • Host:  请求的服务器名称和端口号
        blog.51cto.com
    • Referer: 包含当前正在请求的资源的上一级资源(访问入口)
        https://blog.51cto.com/sonlich/1968933
    • User-Agent:  客户端代理(即浏览器的类型)
             Mozilla/5.0 (Windows NT 10.0; Win64; x64)
    • 条件式请求首部 (和缓存有关)
      • Expect
      • If-Modified-Since:自从指定的时候之后,请求的资源是否发生过修改
      • If-Unmodified-Since
      • If-None-Match:本地缓存中存储的文档的ETag标签是否与服务器文档的ETag不匹配
      • If-Match:
    • 安全请求首部:
      • Authorization:向服务器发送认证信息,如账号和密码
      • Cookie:客户端向服务器发送cookie
      • Cookie2 version 2
    • 代理请求首部
      • Proxy-Authorization:向代理服务器认证
  • 响应首部
    • 信息性

      • Age :响应持续时长
      • Server:服务器程序软件名和版本
    • 协商首部:某资源有多种表示方法时使用
      • Accept-Ranges :服务器可接受的请求范围类型
      • Vary :服务器查看的其它首部列表
    • 安全响应首部
      • Set-Cookie :向客户端设置cookie
      • Set-Cookie2 版本
      • WWW-Authenticate:来自服务器的对客户端的质询认证表单
  • 实体首部:描述entity-body的信息
    • Allow :列出对此实体可使用的请求方法
    • Location:告诉客户端真正的实体位于何处
    • 内容格式:
      • Content-Encoding :内容的编码格式
      • Content-Language:内容的语言
      • Content-Length:内容的大小
      • Content-Locating:实体真正的位置
      • Content-Type :MIME类型
    • 缓存相关
      • ETag :实体的额外标签,基于标签的条件式请求
      • Expires :实体过期时间
      • Last-Modified :实体最近一次修改的时间
  • 扩展首部:额外添加的首部

2.3.7、entity-body :实体-----有用的数据块,请求时附加的数据或响应时附加的数据  

反向代理:将自己扮演为服务端接收请求,支持缓存,拆封报文并重新封装

正向代理:将自己扮演为客户端发起请求

重定向

条件式请求

用户质询认证

Forbidden 请求被禁止,IP控制或用户访问控制不通过时

404 用户请求一个不存在的资源

错误网关:

示例

General
Request URL:http://172.16.100.1/
Request Method:GET
Status Code: OK
Remote Address:172.16.100.1: //服务器地址
Response Headers
view source
Accept-Ranges:bytes
Connection:close // 服务器是非持久连接 KeepAlive off
Content-Encoding:gzip // 实体格式:字符集,包含多种语言编码格式
Content-Length: // 大小
Content-Type:text/html; charset=UTF- // 类型
Date:Sat, Sep :: GMT // 请求报文的创建时间
ETag:"10c-6353-558c0da6c3922" // 实体的额外标签,基于标签的条件式请求
Last-Modified:Sat, Sep :: GMT // 实体最近一次修改的时间
Server:Apache/2.2. (CentOS) // 服务器程序名、版本号
Vary:Accept-Encoding // 服务器查看变化的首部
Request Headers
view source
Accept:text/html,application/xhtml+xml,applicat // 客户端可接受的MIME类型
Accept-Encoding:gzip, deflate, sdch // 客户端可接受的压缩格式
Accept-Charset: // 字符集
Accept-Language:zh-CN,zh;q=0.8 // 客户端可接受的语言编码格式
Cache-Control:max-age= // 缓存控制
Connection:keep-alive //
Host:172.16.100.1 // 服务器主机
User-Agent:Mozilla/5.0 // 用户代理

4、http协议之二的更多相关文章

  1. HTTP协议(二)

    一.请求的格式: (一).请求行 (1).请求方法 1.GET 2.POST 3.PUT 4.DELETE 5.TRACE 6.OPTIONS (2).请求路径 (3).所用的协议 (二).请求头信息 ...

  2. 网络通信 --> 互联网协议(二)

    互联网协议(二) 一.对上一节的总结 我们已经知道,网络通信就是交换数据包.电脑A向电脑B发送一个数据包,后者收到了,回复一个数据包,从而实现两台电脑之间的通信.数据包的结构,基本上是下面这样: 发送 ...

  3. HTTP协议(二)header标头说明

    HTTP协议(二):header标头说明 Header 解释 示例 Accept-Ranges 表明服务器是否支持指定范围请求及哪种类型的分段请求 Accept-Ranges: bytes Age 从 ...

  4. TCP/IP协议(二)tcp/ip基础知识

    今天凌晨时候看书,突然想到一个问题:怎样做到持续学习?然后得出这样一个结论:放弃不必要的社交,控制欲望,克服懒惰... 然后又有了新的问题:学习效率时高时低,状态不好怎么解决?这也是我最近在思考的问题 ...

  5. TCP/IP协议族(二) HTTP报文头解析

    本篇博客我们就来详细的聊一下HTTP协议的常用头部字段,当然我们将其分为请求头和响应头进行阐述.下方是报文头每个字段的格式,首先是头部字段的名称,如Accept,冒号后方紧跟的是该字段名所对应的值,每 ...

  6. 计算机网络相关:应用层协议(二):HTTP

    前言 复习下计算机网络的知识并记录 正文 定义:HTTP协议(HyperText Transfer Protocol,超文本传输协议)是用于从WWW服务器传输超文本到本地浏览器的传送协议. 一.HTT ...

  7. 流媒体协议(二):RTMP协议

    一.概念与摘要 RTMP协议从属于应用层,被设计用来在适合的传输协议(如TCP)上复用和打包多媒体传输流(如音频.视频和互动内容).RTMP提供了一套全双工的可靠的多路复用消息服务,类似于TCP协议[ ...

  8. 图解ARP协议(二)ARP攻击原理与实践

    一.ARP攻击概述 在上篇文章里,我给大家普及了ARP协议的基本原理,包括ARP请求应答.数据包结构以及协议分层标准,今天我们继续讨论大家最感兴趣的话题:ARP攻击原理是什么?通过ARP攻击可以做什么 ...

  9. HTTP协议(二)之确保web安全的HTTPS

    一.概述 https并非是应用层的一种新协议.只是HTTP通信接口部分用SSL和TLS协议替代. 通常,HTTP直接和TCP通信.当使用SSL时,则演变成先和SSL通信,再由SSL和TCP通信了. 简 ...

  10. DTP模型之一:(XA协议之一)XA协议、二阶段2PC、三阶段3PC提交

    XA协议 XA是一个分布式事务协议,由Tuxedo提出.XA中大致分为两部分:事务管理器和本地资源管理器.其中本地资源管理器往往由数据库实现,比如Oracle.DB2这些商业数据库都实现了XA接口,而 ...

随机推荐

  1. number与string的转换

    // number -> string // toString() /* var num = 10; var res = num.toString(); alert(typeof (num)); ...

  2. 超详细Vue实现导航栏绑定内容锚点+滚动动画+vue-router(hash模式可用)

    超详细Vue实现导航栏绑定内容锚点+滚动动画+vue-router(hash模式可用) 转载自:https://www.jianshu.com/p/2ad8c8b5bf75 亲测有效~ <tem ...

  3. day34-python之进程调用

    1.信号量 import threading,time class myThread(threading.Thread): def run(self): if semaphore.acquire(): ...

  4. ECSHOP(3.0.0升级3.6.0)帮助教程

    说明: 本文档只针对于未做过二开的ECSHOP3.0 用户 1.准备材料 先确保正在使用的ECShop系统版本为ecshop3.0.0并且代码没有经过二次开发,然后下载最新的ECShop3.6.0安装 ...

  5. git提交代码并将develop分支合并到master分支上

    提交合并代码流程: git add .git commit -m ''git pushgit checkout mastergit merge develop //将develop 分支与master ...

  6. python基础-生成器

    生成器 概念:但凡在函数内部定义了一个yield,调用函数时,函数体代码不会执行,会返回一个结果,该结果就是生成器.本质上是迭代器,一个自定义的迭代器. # python内获取迭代器的方式 def i ...

  7. tomcat7.x配置APR高并发模式

    Tomcat支持BIO/NIO/APR三种运行模式 ,性能各色春秋! Apr插件提高Tomcat性能 Tomcat可以使用APR来提供超强的可伸缩性和性能,更好地集成本地服务器技术. APR(Apac ...

  8. C语言内存管理(内存池)

    C语言可以使用alloc从栈上动态分配内存. 内存碎片 Malloc/free或者new/delete大量使用会造成内存碎片,这种碎片形成的机理如下: 内存碎片一般是由于空闲的内存空间比要连续申请的空 ...

  9. Linux中快速对字符串进行加密

    1)进行base64的加密和解密 [root@VM_0_10_centos opt]# echo hello |base64aGVsbG8K[root@VM_0_10_centos opt]# ech ...

  10. 通过Nginx实现一个简单的网站维护通知页面

    原文:https://www.zhyd.me/article/106 在网站发版时,总会有那么一小段时间服务是访问不通的,一般用户看到的都会是一个502的错误页面 那么可以通过nginx实现一个简单的 ...