首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

对不起,看完这篇HTTP,真的可以吊打面试官

请求/响应的工作流程如下:服务器以401(未授权) 的状态响应客户端告诉客户端服务器需要认证信息,客户端提供至少一个 www-Authenticate 的响应标头进行授权信息的认证。...这个过程和通用的过程类似,我们就不再详细展开描述了。 禁止访问 如果代理服务器收到的有效凭据不足以获取对给定资源的访问权限,则服务器应使用403 Forbidden状态代码进行响应。...下面是使用共享缓存代理的过程 这个图应该比较好理解,只说一下 Age 的作用,Age 是 HTTP 响应标头告诉客户端源服务器在多久之前创建了响应,它的单位为秒,Age 标头通常接近于0,如果是0则可能是从源服务器获取的...如果这个通用标头不存在的话,则会检查是否存在 Expires 标头。如果 Exprires 标头存在,那么它的值减去 Date 标头的值就可以确定其有效性。...Access-Control-Allow-Origin 是 HTTP 响应标头,指示响应是否能够和给定的源共享资源。

6.4K21

震惊 | HTTP 在疫情期间把我吓得不敢出门了

请求/响应的工作流程如下:服务器以401(未授权) 的状态响应客户端告诉客户端服务器需要认证信息,客户端提供至少一个 www-Authenticate 的响应标头进行授权信息的认证。...禁止访问 如果代理服务器收到的有效凭据不足以获取对给定资源的访问权限,则服务器应使用403 Forbidden状态代码进行响应。...下面是使用共享缓存代理的过程 这个图应该比较好理解,只说一下 Age 的作用,Age 是 HTTP 响应标头告诉客户端源服务器在多久之前创建了响应,它的单位为秒,Age 标头通常接近于0,如果是0则可能是从源服务器获取的...如果这个通用标头不存在的话,则会检查是否存在 Expires 标头。如果 Exprires 标头存在,那么它的值减去 Date 标头的值就可以确定其有效性。...Access-Control-Allow-Origin 是 HTTP 响应标头,指示响应是否能够和给定的源共享资源。

5.4K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    HTTP 返回状态值详解

    ——错误请求,如语法错误 401——请求授权失败 402——保留有效ChargeTo头响应 403——请求不允许 404——没有发现文件、查询或URl 405——用户在Request-Line字段定义的方法不允许...您也可以访问 HTTP 状态码上的 W3C 页获取更多信息。 1xx(临时响应)   表示临时响应并需要请求者继续执行操作的状态码。   100(继续)请求者应当继续提出请求。...如果网页自请求者上次请求后再也没有更改过,您应将服务器配置为返回此响应(称为 If-Modified-Since HTTP 标头)。...404(未找到)服务器找不到请求的网页。例如,对于服务器上不存在的网页经常会返回此代码。   ...417(未满足期望值)服务器未满足"期望"请求标头字段的要求。   5xx(服务器错误)   这些状态码表示服务器在处理请求时发生内部错误。这些错误可能是服务器本身的错误,而不是请求出错。

    3.2K30

    跟我一起探索 HTTP-跨源资源共享(CORS)

    的标头),允许人为设置的字段为 Fetch 规范定义的对 CORS 安全的标头字段集合 。...另外,该请求的 Content-Type 为 application/xml,且使用了自定义的请求标头,所以该请求需要首先发起“预检请求”。...以上例子中,该响应的有效时间为 86400 秒,也就是 24 小时。请注意,浏览器自身维护了一个最大有效时间,如果该标头字段的值超过了最大有效时间,将不会生效。...附带身份凭证的请求与通配符 在响应附带身份凭证的请求时: 服务器不能将 Access-Control-Allow-Origin 的值设为通配符“*”,而应将其设置为特定的域,如:Access-Control-Allow-Origin...HTTP 响应标头字段 本节列出了服务器为访问控制请求返回的 HTTP 响应头,这是由跨源资源共享规范定义的。上一小节中,我们已经看到了这些标头字段在实际场景中是如何工作的。

    39030

    跨域资源共享(CORS)

    您可以在http://arunranga.com/examples/access-control/上找到这些部分中的JavaScript代码片段(以及正在运行的服务器代码实例,这些实例正确处理了这些跨站点请求...由于该请求使用的Content-Type为application/xml,并且由于设置了自定义标头,因此该请求被预检。...Access-Control-Allow-Credentials: true 凭证请求和通配符 响应凭据请求时,服务器必须在Access-Control-Allow-Origin标头的值中指定一个来源,...因为上面示例中的请求标头包含Cookie标头,所以如果Access-Control-Allow-Origin标头的值为“ *” ,则请求将失败。...HTTP响应头部分 本节列出了服务器为跨源资源共享规范定义的访问控制请求发送回的HTTP响应标头。上一节概述了这些功能。

    3.6K50

    掌握并理解 CORS (跨域资源共享)

    同源策略不会阻止对其他源的请求,但是会禁用对 JS 响应的访问。 CORS 标头允许访问跨域响应。 CORS 与 Credentials 一起时需要谨慎。...事例讲解 为了缩小代码量,这里演示部分代码,完全的代码在 Github 上可以得到。...咱们缺少Access-Control-Allow-Origin标头。 但是,为什么我们需要它,它有什么用呢? 同源策略 我们在 JS 中得不到响应结果的原因是同源策略。...为咱们的 API 启用 CORS 现在,咱们希望允许第三方站点(如thirdparty.com)上的 JS 访问咱们的 API 能得到响应。...', '*') res.send(...) }) 这里将access-control-allow-origin标头设置为*,这意味着:允许任何主机访问此URL和获取响应的结果: 非简单的请求和预检

    2.2K10

    跨域资源共享CORS漏洞

    该代码将 Origin 值放在 HTTP 响应头 Access-Control-Allow-Origin 中。现在,此配置将允许来自任何 Origin 的任何脚本向应用程序发出 CORS 请求。...在这种情况下,应用程序在代码中具有弱正则表达式实现,它只检查 HTTP 请求 Origin 标头中任何位置的域名 b0x.com 的存在。...如果 HTTP 标头 Origin 的值为 inb0x.com 或 b0x.comlab.com,正则表达式会将其标记为通过。这种错误配置将导致跨源共享数据。...场景三:信任null源 在这种情况下,应用程序 HTTP 响应标头 Access-Control-Allow-Origin 始终设置为 null。...应用程序接受 Origin 标头中指定的 null 值。 注意事项 如果响应包 Header 中为以下情况 ,则不存在漏洞。

    4K60

    HTTP状态码大全

    接收到此状态时的默认操作为遵循与响应关联的 Location 头。原始请求方法为 POST 时,重定向的请求将使用 GET 方法。...接收到此状态时的默认操作为遵循与响应关联的 Location 头。原始请求方法为 POST 时,重定向的请求将使用 GET 方法。...接收到此状态时的默认操作为遵循与响应关联的 Location 头。原始请求方法为 POST 时,重定向的请求将使用 GET 方法。...接收到此状态时的默认操作为遵循与响应关联的 Location 头。原始请求方法为 POST 时,重定向的请求还将使用 POST 方法。...接收到此状态时的默认操作为遵循与响应关联的 Location 头。原始请求方法为 POST 时,重定向的请求还将使用 POST 方法。

    2.4K40

    HTTP状态码查询

    一些常见的状态代码为: 200 - 服务器成功返回网页 403 - 请求的网页禁止访问 404 - 请求的网页不存在 503 - 服务器暂时不可用 1xx(临时响应),用于表示临时响应并需要请求者执行操作才能继续的状态代码...如果网页自请求者上次请求后再也没有更改过,您应当将服务器配置为返回此响应(称为 If-Modified-Since HTTP 标头)。...404(未找到)  服务器找不到请求的网页。例如,如果请求是针对服务器上不存在的网页进行的,那么,服务器通常会返回此代码。...411(需要有效长度) 服务器不会接受包含无效内容长度标头字段的请求。 412(未满足前提条件) 服务器未满足请求者在请求中设置的其中一个前提条件。...417(未满足期望值) 服务器未满足"期望"请求标头字段的要求。 5xx(服务器错误),这些状态代码表示,服务器在尝试处理请求时发生内部错误。这些错误可能是服务器本身的错误,而不是请求出错。

    1.8K100

    浏览器同源策略与如何解决跨域问题总结

    如果Orign指定的域名在许可范围之内,服务器返回的响应就会多出以下信息头: Access-Control-Allow-Origin: http://api.bob.com // 和Orign⼀直 Access-Control-Allow-Credentials...charset=utf-8 // 表示⽂档类型 如果Orign指定的域名不在许可范围之内,服务器会返回⼀个正常的HTTP回应,浏览器发现没有上⾯的Access-Control-Allow-Origin...这个错误⽆法通过状态码识别,因为返回的状态码可能是200。...在简单请求中,在服务器内,⾄少需要设置字段: Access-Control-Allow-Origin 非简单请求过程: ⾮简单请求是对服务器有特殊要求的请求,⽐如请求⽅法为DELETE或者PUT等。...服务器在收到浏览器的预检请求之后,会根据头信息的三个字段来进⾏判断,如果返回的头信息在中有Access-Control-Allow-Origin这个字段就是允许跨域请求,如果没有,就是不同意这个预检请求

    1.9K20

    C# HTTP系列5 HttpWebResponse.StatusCode属性

    ExpectationFailed 指示服务器未能符合 Expect 标头中给定的预期值。 Forbidden 403 等效于 HTTP 状态 403。 Forbidden 指示服务器拒绝满足请求。...接收到此状态时的默认操作为遵循与响应关联的 Location 标头。 原始请求方法为 POST 时, 重定向的请求将使用 GET 方法。 找到是的同义词重定向。...OK 指示请求成功,且请求的信息包含在响应中。 这是最常接收的状态代码。 PartialContent 206 等效于 HTTP 状态 206。...Redirect 指示请求的信息位于 Location 标头中指定的 URI 处。 接收到此状态时的默认操作为遵循与响应关联的 Location 标头。...接收到此状态时的默认操作为遵循与响应关联的 Location 标头。 原始请求方法为 POST 时,重定向的请求还将使用 POST 方法。

    2.2K20

    三种对CORS错误配置的利用方法

    因此,为了在不影响应用程序安全状态的情况下实现信息共享,在HTML5中引入了跨源资源共享(CORS)。...关键 CORS 标头 有许多与CORS相关的HTTP标头,但以下三个响应标头对于安全性最为重要: Access-Control-Allow-Origin:指定哪些域可以访问域资源。...Access-Control-Allow-Credentials:指定浏览器是否将使用请求发送cookie。仅当allow-credentials标头设置为true时,才会发送Cookie。...三个攻击场景 利用CORS标头中错误配置的通配符(*) 最常见的CORS配置错误之一是错误地使用诸如(*)之类的通配符,允许域请求资源。这通常设置为默认值,这意味着任何域都可以访问此站点上的资源。...标头设置的响应。

    3K20

    http状态码

    304(未修改) 自从上次请求后,请求的网页未被修改过。服务器返回此响应时,不会返回网页内容。 如果网页自请求者上次请求后再也没有更改过,您应当将服务器配置为返回此响应。...404(未找到) 服务器找不到请求的网页。例如,对于服务器上不存在的网页经常会返回此代码。...该代码与 404(未找到)代码相似,但在资源以前存在而现在不存在的情况下,有时会用来替代 404 代码。如果资源已永久删除,您应当使用 301 指定资源的新位置。...411(需要有效长度) 服务器不接受不含有效内容长度标头字段的请求。 412(未满足前提条件) 服务器未满足请求者在请求中设置的其中一个前提条件。...417(未满足期望值) 服务器未满足"期望"请求标头字段的要求。 500至505表示的意思是:服务器在尝试处理请求时发生内部错误。这些错误可能是服务器本身的错误,而不是请求出错。

    1.4K30

    ASP Net Core – CORS 预检请求

    应用不会设置、、、或以外的请求标头 Accept Accept-Language Content-Language Content-Type Last-Event-ID 。...,服务器必须仅通过添加以下标头来允许源:“ Access-Control-Allow-Origin:*”, 收到预检请求后,浏览器将使用OPTIONS方法自动发送初始请求,以确定实际请求可以安全发送的请求...下面的示例显示,在不同来源运行的blazor 应用程序的调用将失败,因为服务器未发出“ Access-Control-Allow-Origin”标头: ? Blazor App 请求API ? ?...该调用是一个简单的请求,但由于服务器不信任源而仍然失败。我们可以告诉他信任它,以解决此问题。 我们要做的就是向它发送带有适当Header 的状态代码为200的响应。...并且对于我们的请求,我们还将指定Content-Type标头 -- application/vnd.serilog.clef ? 第一个请求是“选项”请求: ? 第二个请求是我们的请求: ?

    1.2K20

    HTTP协议状态码详解

    HTTP协议状态码详解(HTTP Status Code) 使用PHP/JSP 或者javascript都会用到http的不同状态,一些常见的状态码为: 200 – 服务器成功返回网页 404 – 请求的网页不存在...503 – 服务不可用 1xx(临时响应) 表示临时响应并需要请求者继续执行操作的状态代码 代码 说明 100 (继续) 请求者应当继续提出请求。...410 (已删除) 如果请求的资源已永久删除,服务器就会返回此响应。 411 (需要有效长度) 服务器不接受不含有效内容长度标头字段的请求。...416 (请求范围不符合要求) 如果页面无法提供请求的范围,则服务器会返回此状态代码。 417 (未满足期望值) 服务器未满足”期望”请求标头字段的要求。...先决条件的另外一个例子就是 If-Match 头,这个一般用在 PUT 请求上用于指示只更新没被改变的资源,这在多个客户端使用 HTTP 服务时用来防止彼此间不会覆盖相同内容。

    66430

    HTTP协议状态码详解(HTTP Status Code)

    使用ASP.NET/PHP/JSP 或者javascript都会用到http的不同状态,一些常见的状态码为: 200 – 服务器成功返回网页 404 – 请求的网页不存在 503 – 服务不可用...1xx(临时响应) 表示临时响应并需要请求者继续执行操作的状态代码。...410   (已删除)  如果请求的资源已永久删除,服务器就会返回此响应。 411   (需要有效长度) 服务器不接受不含有效内容长度标头字段的请求。...416   (请求范围不符合要求) 如果页面无法提供请求的范围,则服务器会返回此状态代码。 417   (未满足期望值) 服务器未满足”期望”请求标头字段的要求。...先决条件的另外一个例子就是 If-Match 头,这个一般用在 PUT 请求上用于指示只更新没被改变的资源,这在多个客户端使用 HTTP 服务时用来防止彼此间不会覆盖相同内容。

    1.8K80

    http状态代码含义

    一些常见的状态代码为: 200 - 服务器成功返回网页 404 - 请求的网页不存在 503 - 服务器暂时不可用 下面提供 HTTP 状态代码的完整列表。 点击链接可了解详情。...如果网页自请求者上次请求后再也没有更改过,您应当将服务器配置为返回此响应(称为 If-Modified-Since HTTP 标头)。...404 未找到 服务器找不到请求的网页。 例如,对于服务器上不存在的网页经常会返回此代码。...411 需要有效长度 服务器不接受不含有效内容长度标头字段的请求。 412 为满足前提条件 服务器未满足请求者在请求中设置的其中一个前提条件。...417 未满足期望值 服务器未满足”期望”请求标头字段的要求。 5xx 服务器错误 这些状态代码表示服务器在尝试处理请求时发生内部错误。 这些错误可能是服务器本身的错误,而不是请求出错。

    1.1K20
    领券