简单讲述了HTTP方面知识,学Web开发,怎么可以不懂这方面知识勒。
超文本传输协议(Hypertext Transfer Protocol,HTTP)是一个简单的请求-响应协议,它通常运行在TCP之上。它指定了客户端可能发送给服务器什么样的消息以及得到什么样的响应。请求和响应消息的头以ASCII形式给出;而消息内容则具有一个类似MIME的格式。这个简单模型是早期Web成功的有功之臣,因为它使开发和部署非常地直截了当。HTTP
协议 属于 最高层的应用层 --百度百科
计算机网络体系结构方面的知识,大家想去了解的,可以去找找哦。就是计算机网络的各层 + 其协议的集合。
HTTP是基于客户/服务器模式(也就是c/s架构),且面向连接的。典型的HTTP事务处理有如下的过程:
(1)客户与服务器建立连接;
(2)客户向服务器提出请求;
(3)服务器接受请求,并根据请求返回相应的文件作为应答;
(4)客户与服务器关闭连接。
这是粗略的知识点。
我们都知道访问 www.baidu.com就能到百度的页面 但是具体的流程是什么样的勒?
重要:例如:在浏览器地址栏键入URL,按下回车之后会经历以下流程:
请求方式一共有9种。
/ | 请求方式 | 描述 |
---|---|---|
1 | GET | 请求指定的页面信息,并返回实体主体。 |
2 | HEAD | 类似于 GET 请求,只不过返回的响应中没有具体的内容,用于获取报头 |
3 | POST | 向指定资源提交数据进行处理请求(例如提交表单或者上传文件)。数据被包含在请求体中。POST 请求可能会导致新的资源的建立和/或已有资源的修改。 |
4 | PUT | 从客户端向服务器传送的数据取代指定的文档的内容。 |
5 | DELETE | 请求服务器删除指定的页面。 |
6 | CONNECT | HTTP/1.1 协议中预留给能够将连接改为管道方式的代理服务器。 |
7 | OPTIONS | 允许客户端查看服务器的性能。 |
8 | TRACE | 回显服务器收到的请求,主要用于测试或诊断。 |
9 | PATCH | 是对 PUT 方法的补充,用来对已知资源进行局部更新 。 |
我们最常见到的 就是GET 、POST、PUT、DELETE四种方式。
GET 的话就像你使用百度查询一样,查询的文字会跟在url上。
POST 的话就是你在网页登录的微博的时候,这个时候提交表单就会使用POST方式。
PUT的话就是你修改洛谷的名称的时候 就是用的PUT方式。
DELETE 就是你在删除你发的第一条微博的时候就可以使用DELETE 方式 。
当然这都不是固定的,是偏向result风格的开发方式而已。其他的也是可以实现的。
我们都知道访问 www.baidu.com就能到百度的页面 但是这一行url 代表着什么 可能大家并不是那么了解。可能只知道这个url能够定位到一个网络上的资源。
url详解
schema://host[:port#]/path/.../[;url-params][?query-string]
举个栗子
http://www.crush.com/wyh/blog;id=999?e=sviergn&x=true#stuff
Schema: http
host: www.crushom
path: /wyh/blog
URL params: id=999
Query String: name=sviergn&x=true
我们之所以常常不需要输入 “http://” 的部分,因为绝大多数网页内容是超文本传输协议文件。同样,“80”是超文本传输协议文件的常用端口号,因此一般也不必写明。一般来说用户只要键入统一资源定位符的一部分(www.luffycity.com:80/news/index.html?id=250&page=1)就可以了。
如果想要具体知道某一个状态码的信息。
这边建议可以直接查看百度百科 https://baike.baidu.com/item/HTTP
常见的状态码
状态码 | 描述 |
---|---|
200 | 表示从客户端发送给服务器的请求被正常处理并返回; |
301 | 永久性重定向,表示请求的资源被分配了新的URL,之后应使用更改的URL; |
302 | 临时性重定向,表示请求的资源被分配了新的URL,希望本次访问使用新的URL; |
307 | 临时重定向,与303有着相同的含义,307会遵照浏览器标准不会从POST变成GET; |
400 | 表示请求报文中存在语法错误; |
403 | 服务器拒绝访问(没有权限访问) |
404 | 表示服务器上无法找到请求的资源 (找不到) |
500 | 一般是服务端出现bug或者是一些临时的错误(就是我们的代码中出现错误) |
\**Cache-Control:public\**
**响应会被缓存,并且在多用户间共享。正常情况, 如果要求HTTP认证,响应会自动设置为 private.Cache-Control:no-store
**在任何条件下,响应都不会被缓存,并且不会被写入到客户端的磁盘里,这也是基于安全考虑的某些敏感的响应才会使用这个。Cookie是用来存储一些用户信息以便让服务器辨别用户身份的(大多数需要登录的网站上面会比较常见),比如cookie会存储一些用户的用户名和密码,当用户登录后就会在客户端产生一个cookie来存储相关信息,这样浏览器通过读取cookie的信息去服务器上验证并通过后会判定你是合法用户,从而允许查看相应网页。当然cookie里面的数据不仅仅是上述范围,还有很多信息可以存储是cookie里面,比如sessionid等。
参考:https://juejin.cn/post/6844903745004765198
应答头 | 说明 |
---|---|
Allow | 服务器支持哪些请求方法(如GET、POST等)。 |
Content-Encoding | 文档的编码(Encode)方法。只有在解码之后才可以得到Content-Type头指定的内容类型。 |
Content-Length | 表示内容长度。只有当浏览器使用持久HTTP连接时才需要这个数据。 |
Content-Type | 表示后面的文档属于什么MIME类型。Servlet默认为text/plain, |
Date | 当前的GMT时间。你可以用setDateHeader来设置这个头以避免转换时间格式的麻烦。 |
Expires | 应该在什么时候认为文档已经过期,从而不再缓存它? |
Last-Modified | 文档的最后改动时间。 |
Location | 表示客户应当到哪里去提取文档。 |
Refresh | 表示浏览器应该在多少时间之后刷新文档,以秒计。 |
Server | 服务器名字。Servlet一般不设置这个值,而是由Web服务器自己设置。 |
Set-Cookie | 设置和页面关联的Cookie。 |
WWW-Authenticate | 客户应该在Authorization头中提供什么类型的授权信息? |
常见的媒体格式类型如下:
以application开头的媒体格式类型:
另外一种常见的媒体格式是上传文件之时使用的:
划水划完啦。