HTTP和HTTPS的区别?
什么是强缓存和协商缓存
(1)max-age:用来设置资源(representations)可以被缓存多长时间,单位为秒;(2)s-maxage:和max-age是一样的,不过它只针对代理服务器缓存而言;(3)public:指示响应可被任何缓存区缓存;(4)private:只能针对个人用户,而不能被代理服务器缓存;(5)no-cache:强制客户端直接向服务器发送请求,也就是说每次请求都必须向服务器发送 。服务器接收到请求,然后判断资源是否变更 , 是则返回新内容,否则返回304,未变更 。这个很容易让人产生误解,使人误以为是响应不被缓存 。实际上Cache-Control:no-cache是会被缓存的,只不过每次在向客户端(浏览器)提供响应数据时,缓存都要向服务器评估缓存响应的有效性 。(6)no-store:禁止一切缓存(这个才是响应不被缓存的意思) 。
协商缓存: 向服务器发送请求 , 服务器会根据这个请求的request header的一些参数来判断是否命中协商缓存,如果命中,则返回304状态码并带上新的response header通知浏览器从缓存中读取资源
Last-Modifed/If-Modified-Since和Etag/If-None-Match是分别成对出现的,呈一一对应关系
Etag/If-None-Match:
Etag:
If-None-Match:
Last-Modifed/If-Modified-Since:
Last-Modified:
If-Modified-Since:
常见的HTTP状态码有哪些,都代表了什么含义?2XX(Success 成功状态码)
2XX 响应的结果标明请求被正常处理了
200 OK
在响应报文内 , 随状态码一起返回的信息会因方法的不同而发生改变 。比如,使用 GET 方法时 , 对应请求资源的实体会作为响应返回;而使用 HEAD 方法 时,对应请求资源的实体首部不随报文主体作为响应返回(即在响应中只返回首部,不会返回实体的主体部分) 。
204 No Content
该状态码代表服务器接收的请求已成功处理,但在返回的响应报文中不含实体的主体部分 。另外 , 也不允许返回任何实体的主体 。比如 , 当从浏览器发出请求 处理后 , 返回 204 响应,那么浏览器显示的页面不发生更新 。
206 Partial Content
3XX(Redirection 重定向状态码)
3XX 响应结果表明浏览器需要执行某些特殊的处理以正确处理请求
301 Moved Permanently
该状态码表示请求的资源已被分配了新的 URI,以后应使用资源现在所指的 URI 。也就是说,如果已经把资源对应的 URI 保存为书签了 , 这时应该按 Location 首部字段提示的 URI 重新保存
302 Found
该状态码表示请求的资源已被分配了新的 URI,希望用户(本次)能使用新的 URI 访问 。和 301 Moved Permanently 状态码相似,但 302 状态码代表的资源不是被永久移动,只是临时性质的 。换句话说,已移动的资源对应的 URI 将来还有可能发生改 变 。比如,用户把 URI 保存成书签,但不会像 301 状态码出现时那样去更新书签,而是仍旧保留返回 302 状态码的页面对应的 URI 。
303 See Other
303 状态码和 302 Found 状态码有着相同的功能,但 303 状态码明确表示客户端应当采用 GET 方法获取资源 , 这点与 302 状态码有区别 。比如,当使用 POST 方法访问 CGI 程序 , 其执行后的处理结果是希望客户端能以 GET 方法重定向到另一个 URI 上去时,返回 303 状态码 。虽然 302 Found 状态码也可以实现相同的功能,但这里使用 303 状态码是最理想的
304 Not Modified
该状态码表示客户端发送附带条件的请求时,服务器端允许请求访问资源,但未满足条件的情况 。304 状态码返回时,不包含任何响应的主体部分 。304 虽 然被划分在 3XX 类别中,但是和重定向没有关系 。
307 Temporary Redirect
临时重定向 。该状态码与 302 Found 有着相同的含义 。尽管 302 标准禁止 POST 变换成 GET,但实际使用时大家并不遵守
307 会遵照浏览器标准 , 不会从 POST 变成 GET 。但是,对于处理响应时的行为,每种浏览器有可能出现不同的情况
4XX(Client Error 客户端错误状态码)
4XX 的响应结果表明客户端是发生错误的原因所在
400 Bad Request
该状态码表示请求报文中存在语法错误 。当错误发生时 , 需修改请求的内容后再次发送请求 。另外,浏览器会像 200 OK 一样对待该状态码 。
401 Unauthorized
该状态码表示发送的请求需要有通过 HTTP 认证(BASIC 认证、DIGEST 认证)的认证信息 。另外若之前已进行过 1 次请求,则表示用 户认证失败
返回含有 401 的响应必须包含一个适用于被请求资源的 WWW-Authenticate 首部用以质询(challenge)用户信息 。当浏览器初次接收到 401 响应,会弹出认证用的对话窗口
403 Forbidden
该状态码表明对请求资源的访问被服务器拒绝了 。服务器端没有必要给出拒绝的详细理由,但如果想作说明的话,可以在实体的主体部分对原因进行描述,这样就能让用户看到了
未获得文件系统的访问授权,访问权限出现某些问题(从未授权的发送源 IP 地址试图访问)等列举的情况都可能是发生 403 的原因
404 Not Found
该状态码表明服务器上无法找到请求的资源 。除此之外 , 也可以在服务器端拒绝请求且不想说明理由时使用
405 Method Not Allowed
该状态码标明,客户端请求的方法虽然能被服务器识别,但是服务器禁止使用该方法
客户端可以通过 OPTIONS 方法来查看服务器允许的访问方法, 如下
Access-Control-Allow-Methods →GET,HEAD,PUT,PATCH,POST,DELETE5XX(Server Error 服务器错误状态码)
5XX 的响应结果表明服务器本身发生错误
500 Internal Server Error
该状态码表明服务器端在执行请求时发生了错误 。也有可能是 Web 应用存在的 bug 或某些临时的故障
502 Bad Gateway
该状态码表明扮演网关或代理角色的服务器 , 从上游服务器中接收到的响应是无效的
503 Service Unavailable
该状态码表明服务器暂时处于超负载或正在进行停机维护,现在无法处理请求 。如果事先得知解除以上状况需要的时间,最好写入 RetryAfter 首部字段再返回 给客户端
状态码和状况的不一致 不少返回的状态码响应都是错误的,但是用户可能察觉不到这点 。比如 Web 应用程序内部发生错误,状态码依然返回 200 OK,这种情况也经常遇到 。
【面试问到HTTP就这么回答】以上就是朝夕生活(www.30zx.com)关于“面试问到HTTP就这么回答”的详细内容,希望对大家有所帮助!
猜你喜欢
- 最强PS2模拟器-PCSX2软件使用全攻略
- OLED拼接屏,常见的5个故障及维修方法
- Win10免费的多屏协同竟用不了?教你修复这毛病
- 在家上网速度慢、总掉线怎么办?
- 这次全了!广联达钢筋算量软件使用大解疑!
- 计算机网络中常见的几类软件故障
- 程序出现异常不用慌,常见手段来帮忙
- 桌面快捷方式异常,图标变未知程序怎么解决
- 临沂管家婆软件数据库问题处理小技巧