热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

HTTP协议知识点(二)

一台HTTP服务器可以搭建多个Web站点,相同的IP地址下,虚拟主机可以寄存多个不同主机名和域名的Web网站,因此在发送HTTP请求时&#




一台HTTP服务器可以搭建多个Web站点,相同的IP地址下,虚拟主机可以寄存多个不同主机名和域名的Web网站,因此在发送HTTP请求时,必须在Host首部内完整指定主机名或域名的URI

代理:一种有转发功能的应用程序,扮演了位于服务器和客户端中间人的角色,接受由客户端发送的请求并转发给服务器,同时也接收服务器返回的响应并转发给客户端。

网关:转发其他服务器通信数据的服务器,接受从客户端发送过来的请求时,它会想自己拥有资源的源服务器一样对请求进行处理。也可以由HTTP请求转化为其他通信协议,此外网关也能提高通信的完全性,可以在客户端和网关之间的通信线路上加密以确保连接的安全
在这里插入图片描述

隧道:是在相隔甚远的客户端和服务器之间进行中转,并保持双方通信连接的应用程序。使用SSL等加密手段进行通信。确保客户端能与服务器进行安全的通信
在这里插入图片描述

代理服务器:
在这里插入图片描述

代理服务器优势:利用缓存技术减少网络带宽的流量,组织内部针对特定网站的访问控制,以获取访问日志为主要目的

缓存:代理服务器或客户端本地磁盘内保持的资源副本,缓存服务器是代理服务器的一种。利用缓存可以避免多次从源服务器转发资源,因此客户端可以就近从缓存服务器上获取资源,而源服务器也不必多次处理相同的请求了。缓存存在一个有效期


HTTP报文首部

在这里插入图片描述

HTTP响应报文由HTTP版本,状态码,HTTP首部字段3部分:
首部字段是为了给浏览器和服务器提供报文主体大小,所使用的语言,认证信息等内容。

1.通用首部字段(General Header Fields):请求报文和响应报文两方都会使用的首部
2.请求首段字段(Request Header Fields):从客户端向服务端发送请求报文时使用的首部,补充了请求的附加内容,客户端信息,响应内容相关优先级等信息
3.响应首部字段(Response Header Fields):从服务器端向客户端返回响应报文时使用的首部,补充了响应的附加内容,也会要求客户端附加额外的内容信息
4.实体首部字段(Entity Header Fields):针对请求报文和响应报文的实体部分使用的首部,补充了资源内容更新时间等与实体有关的信息

首段字段结构:首部字段名和字段值构成的,中间使用冒号:分割

通用首部字段
在这里插入图片描述

请求首部字段
在这里插入图片描述

响应首部字段
在这里插入图片描述

实体首部字段
在这里插入图片描述

HTTP首部字段将定义成缓存代理和非缓存代理的行为

端到端首部(End-to-End Header):分在次类别中的首部会转发给请求/响应对应的最终接受目标,且必须保存在由缓存生成的响应中,另外规定它必须被转发
逐跳首部(Hop-by-hop Header):分在此类别中的首部只对单次转发有效,会因通过缓存或代理而不再转发,如果使用hop-by-hop首部,需要提供Connection首部字端
Connection
Keep-Alive
Proxy-Authenticate
Proxy-Authorization
Trailer
TE
Transfer-Encoding
Upgrade这八个都是逐跳首部(其他字段都是端到端字段)

cache-Control:控制缓存行为。

格式:Cache-Control:private(public 表示是否可以缓存), max-age=0, no-cache

缓存请求指令
在这里插入图片描述

缓存响应指令
在这里插入图片描述

Cache-Control中部分操作

Cache-Control:min-fresh=60(单位:秒):指令要求缓存服务器返回至少还未过指定时间的缓存资源
Cache-Control:max-stale=3600(秒):权限高于min-fresh,只要没过max-stale时间就可以被客户端接受响应,不指定时间就是永久
only-if-cached:表示客户端仅在缓存服务器本地缓存目标资源的情况下才会要求其返回,也就是要求缓存服务器不重新加载响应,也不会再次确认资源的有效性
must-revalidate:代理会向源服务器再次验证即将返回的响应缓存目前是否仍然有效,权限甚至比max-stale更高,直接忽视它
proxy-revalidate:要求所有的缓存服务器在接收到客户端带有该指令的请求返回响应之前,必须再次验证缓存的有效性
no-transform:无论是在请求还是在响应中,缓存都不能改变实体主体的媒体类型,防止缓存或代理压缩图片的操作

HTTP1.1警告码
在这里插入图片描述


请求首部字段

用于补充请求的附加信息,客户端信息,对响应内容相关的优先级等内容


Accept

可通知服务器,用户代理能够处理的媒体类型和媒体类型的相对优先级,优先级使用q=来额外表示权重值

Accept-Charset:用来通知服务器用户代理支持的字符集及字符集的相对优先顺序,用于内容协商机制的服务器驱动协商
格式:Accept-Charset: iso-8859-5, unicode-1-1;q=0.8
Accept-Encoding:用来告知服务器用户代理支持的内容编码及内容编码的优先级顺序
格式:Accept-Encoding: gzip, deflate
Accept-Language:告诉服务器用户代理能够处理的自然语言集
格式Accept-Language: zh-cn,zh;q=0.7,en-us,en;q=0.3
Authorization: 告知服务器用户代理的认证信息
格式:Authorization: Basic dWVub3NlbjpwYXNzd29yZA==
Host:告知服务器请求的资源所处的互联网主机名和端口号,必须被包含在请求内的首部字段

Proxy-Authorization:客户端和代理服务器之间的相互认证

Referer:告知服务器请求的原始资源的URI

User-Agent:用于传达浏览器的种类和用户代理名称等信息给服务器

格式:User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64; rv:13.0) Gec


响应首部字段

由服务器端向客户端返回响应报文中所使用的字段,用于补充响应的附加信息,服务器信息以及对客户端的附加要求等信息

Accept-Ranges: 用来告知客户端服务器是否能够处理范围请求以指定获取服务器端某个部分的资源

Age:告知客户端源服务器在多久之前创建了响应,字段值的单位为秒

ETag:客户端的实体标识,ETag有强弱之分,强ETag不论实体发生多么细微的变化都会该改变其值,而弱ETag只用于提示资源是否相同,只有资源发生了根本变化,产生差异才会改变ETag值

Location: http://www.usagidesign.jp/sample.html 使用首部字段可以将响应接收方引导至某个与请求URI位置不同的资源,几乎所有的浏览器在接收到包含首部字段Location的响应后,都会强制性地尝试对已提示的重定向资源访问。

Server:首部字段Server告诉客户端当前服务器上安装的HTTP服务器应用程序的信息,不单单会标出服务器上的软件应用名称,还有可能包括版本号和安装时启动的可选项

Vary:可对缓存进行控制
在这里插入图片描述

如果语言不同,则只能从源服务器端获取资源后才能作为响应返回


实体首部字段

实体首部字段是包含在请求报文和响应报文中的实体部分所使用的的首部,用户补充内容的更新时间等与实体相关的信息

Allow:用户通知客户端能够支持Request-URI指定资源的所有HTTP方法。
Content-Encoding:告知客户端服务器对实体的主体部分选用的内容编码方式,内容编码是指在不丢失实体信息的前提下所进行的压缩
Content-Location 表示的是报文主体返回资源对应的 URI
Content-Range:告知客户端作为响应返回的实体的那个部分符合范围请求
Expires:将资源失效的日期告知客户端
Last-Modified 指明资源最终修改的时间

为COOKIE服务的首部字段
在这里插入图片描述

Set-COOKIE字段属性和含义
在这里插入图片描述


其他首部字段

X-Frame-Options:用于控制网站内容再其他Web网站的Frame标签内的显示问题,主要目的是为了防止点击劫持攻击

X-XSS-Protection:针对XSS的一种策略,用于控制浏览器XSS防护机制的开关

DNT:Do Not Track的简称,意为拒绝个人信息被收集,是表示拒绝被精准广告追踪的一种方法

P3P:可以让Web网站上的个人隐私变成一种仅供程序可理解的形式,以达到保护用户隐私的目的







推荐阅读
  • 这是原文链接:sendingformdata许多情况下,我们使用表单发送数据到服务器。服务器处理数据并返回响应给用户。这看起来很简单,但是 ... [详细]
  • SpringBoot uri统一权限管理的实现方法及步骤详解
    本文详细介绍了SpringBoot中实现uri统一权限管理的方法,包括表结构定义、自动统计URI并自动删除脏数据、程序启动加载等步骤。通过该方法可以提高系统的安全性,实现对系统任意接口的权限拦截验证。 ... [详细]
  • Android中高级面试必知必会,积累总结
    本文介绍了Android中高级面试的必知必会内容,并总结了相关经验。文章指出,如今的Android市场对开发人员的要求更高,需要更专业的人才。同时,文章还给出了针对Android岗位的职责和要求,并提供了简历突出的建议。 ... [详细]
  • 本文介绍了Java工具类库Hutool,该工具包封装了对文件、流、加密解密、转码、正则、线程、XML等JDK方法的封装,并提供了各种Util工具类。同时,还介绍了Hutool的组件,包括动态代理、布隆过滤、缓存、定时任务等功能。该工具包可以简化Java代码,提高开发效率。 ... [详细]
  • 本文介绍了作者在开发过程中遇到的问题,即播放框架内容安全策略设置不起作用的错误。作者通过使用编译时依赖注入的方式解决了这个问题,并分享了解决方案。文章详细描述了问题的出现情况、错误输出内容以及解决方案的具体步骤。如果你也遇到了类似的问题,本文可能对你有一定的参考价值。 ... [详细]
  • 自动轮播,反转播放的ViewPagerAdapter的使用方法和效果展示
    本文介绍了如何使用自动轮播、反转播放的ViewPagerAdapter,并展示了其效果。该ViewPagerAdapter支持无限循环、触摸暂停、切换缩放等功能。同时提供了使用GIF.gif的示例和github地址。通过LoopFragmentPagerAdapter类的getActualCount、getActualItem和getActualPagerTitle方法可以实现自定义的循环效果和标题展示。 ... [详细]
  • 本文介绍了南邮ctf-web的writeup,包括签到题和md5 collision。在CTF比赛和渗透测试中,可以通过查看源代码、代码注释、页面隐藏元素、超链接和HTTP响应头部来寻找flag或提示信息。利用PHP弱类型,可以发现md5('QNKCDZO')='0e830400451993494058024219903391'和md5('240610708')='0e462097431906509019562988736854'。 ... [详细]
  • Nginx使用(server参数配置)
    本文介绍了Nginx的使用,重点讲解了server参数配置,包括端口号、主机名、根目录等内容。同时,还介绍了Nginx的反向代理功能。 ... [详细]
  • eclipse学习(第三章:ssh中的Hibernate)——11.Hibernate的缓存(2级缓存,get和load)
    本文介绍了eclipse学习中的第三章内容,主要讲解了ssh中的Hibernate的缓存,包括2级缓存和get方法、load方法的区别。文章还涉及了项目实践和相关知识点的讲解。 ... [详细]
  • 计算机存储系统的层次结构及其优势
    本文介绍了计算机存储系统的层次结构,包括高速缓存、主存储器和辅助存储器三个层次。通过分层存储数据可以提高程序的执行效率。计算机存储系统的层次结构将各种不同存储容量、存取速度和价格的存储器有机组合成整体,形成可寻址存储空间比主存储器空间大得多的存储整体。由于辅助存储器容量大、价格低,使得整体存储系统的平均价格降低。同时,高速缓存的存取速度可以和CPU的工作速度相匹配,进一步提高程序执行效率。 ... [详细]
  • Python瓦片图下载、合并、绘图、标记的代码示例
    本文提供了Python瓦片图下载、合并、绘图、标记的代码示例,包括下载代码、多线程下载、图像处理等功能。通过参考geoserver,使用PIL、cv2、numpy、gdal、osr等库实现了瓦片图的下载、合并、绘图和标记功能。代码示例详细介绍了各个功能的实现方法,供读者参考使用。 ... [详细]
  • Linux环境变量函数getenv、putenv、setenv和unsetenv详解
    本文详细解释了Linux中的环境变量函数getenv、putenv、setenv和unsetenv的用法和功能。通过使用这些函数,可以获取、设置和删除环境变量的值。同时给出了相应的函数原型、参数说明和返回值。通过示例代码演示了如何使用getenv函数获取环境变量的值,并打印出来。 ... [详细]
  • 本文介绍了PE文件结构中的导出表的解析方法,包括获取区段头表、遍历查找所在的区段等步骤。通过该方法可以准确地解析PE文件中的导出表信息。 ... [详细]
  • 数字账号安全与数据资产问题的研究及解决方案
    本文研究了数字账号安全与数据资产问题,并提出了解决方案。近期,大量QQ账号被盗事件引起了广泛关注。欺诈者对数字账号的价值认识超过了账号主人,因此他们不断攻击和盗用账号。然而,平台和账号主人对账号安全问题的态度不正确,只有用户自身意识到问题的严重性并采取行动,才能推动平台优先解决这些问题。本文旨在提醒用户关注账号安全,并呼吁平台承担起更多的责任。令牌云团队对此进行了长期深入的研究,并提出了相应的解决方案。 ... [详细]
  • GPT-3发布,动动手指就能自动生成代码的神器来了!
    近日,OpenAI发布了最新的NLP模型GPT-3,该模型在GitHub趋势榜上名列前茅。GPT-3使用的数据集容量达到45TB,参数个数高达1750亿,训练好的模型需要700G的硬盘空间来存储。一位开发者根据GPT-3模型上线了一个名为debuid的网站,用户只需用英语描述需求,前端代码就能自动生成。这个神奇的功能让许多程序员感到惊讶。去年,OpenAI在与世界冠军OG战队的表演赛中展示了他们的强化学习模型,在限定条件下以2:0完胜人类冠军。 ... [详细]
author-avatar
笨笨的小白鼠
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有