网站首页 > java教程 正文
简单讲述了HTTP方面知识,学Web开发,怎么可以不懂这方面知识勒。
Java开发就没啥不用懂的哈,前端、后端、测试、运维...还什么不需要的吗
很喜欢一句话:八小时内谋生活,八小时外谋发展
一、什么是HTTP协议
超文本传输协议(Hypertext Transfer Protocol,HTTP)是一个简单的请求-响应协议,它通常运行在TCP之上。它指定了客户端可能发送给服务器什么样的消息以及得到什么样的响应。请求和响应消息的头以ASCII形式给出;而消息内容则具有一个类似MIME的格式。这个简单模型是早期Web成功的有功之臣,因为它使开发和部署非常地直截了当。HTTP协议 属于 最高层的应用层 --百度百科
计算机网络体系结构方面的知识,大家想去了解的,可以去找找哦。就是计算机网络的各层 + 其协议的集合。
二、HTTP 工作原理
HTTP是基于客户/服务器模式(也就是c/s架构),且面向连接的。典型的HTTP事务处理有如下的过程:
(1)客户与服务器建立连接;
(2)客户向服务器提出请求;
(3)服务器接受请求,并根据请求返回相应的文件作为应答;
(4)客户与服务器关闭连接。
这是粗略的知识点。
我们都知道访问 www.baidu.com就能到百度的页面 但是具体的流程是什么样的勒?
重要:例如:在浏览器地址栏键入URL,按下回车之后会经历以下流程:
- 浏览器向 DNS 服务器请求解析该 URL 中的域名所对应的 IP 地址;
- 解析出 IP 地址后,根据该 IP 地址和默认端口 80,和服务器建立TCP连接;
- 浏览器发出读取文件(URL 中域名后面部分对应的文件)的HTTP 请求,该请求报文作为 TCP 三次握手的第三个报文的数据发送给服务器;
- 服务器对浏览器请求作出响应,并把对应的 html 文本发送给浏览器;
- 释放 TCP连接;
- 浏览器将该 html 文本并显示内容;
三、HTTP 请求方式
请求方式一共有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风格的开发方式而已。其他的也是可以实现的。
四、URL 讲解
我们都知道访问 www.baidu.com就能到百度的页面 但是这一行url 代表着什么 可能大家并不是那么了解。可能只知道这个url能够定位到一个网络上的资源。
url详解
schema://host[:port#]/path/.../[;url-params][?query-string]
复制代码
- scheme 指定低层使用的协议(例如:http, https, ftp)
- host HTTP服务器的IP地址或者域名
- port# HTTP服务器的默认端口是80,这种情况下端口号可以省略。如果使用了别的端口,必须指明,例如 www.cnblogs.com:8080/
- path 访问资源的路径
- url-params
- query-string 发送给http服务器的数据
举个栗子
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”是超文本传输协议文件的常用端口号,因此一般也不必写明。一般来说用户只要键入统一资源定位符的一部分
五、HTTP 状态码
- 1XX 提示信息 - 表示请求已被成功接收,继续处理
- 2XX 成功 - 表示请求已被成功接收,理解,接受
- 3XX 重定向 - 要完成请求必须进行更进一步的处理
- 4XX 客户端错误 - 请求有语法错误或请求无法实现
- 5XX 服务器端错误 - 服务器未能实现合法的请求
如果想要具体知道某一个状态码的信息。
这边建议可以直接查看百度百科 baike.baidu.com/item/HTTP
常见的状态码
状态码 | 描述 |
200 | 表示从客户端发送给服务器的请求被正常处理并返回; |
301 | 永久性重定向,表示请求的资源被分配了新的URL,之后应使用更改的URL; |
302 | 临时性重定向,表示请求的资源被分配了新的URL,希望本次访问使用新的URL; |
307 | 临时重定向,与303有着相同的含义,307会遵照浏览器标准不会从POST变成GET; |
400 | 表示请求报文中存在语法错误; |
403 | 服务器拒绝访问(没有权限访问) |
404 | 表示服务器上无法找到请求的资源 (找不到) |
500 | 一般是服务端出现bug或者是一些临时的错误(就是我们的代码中出现错误) |
六、HTTP Request header (请求头信息)
1.Accept
- Accept: text/html 浏览器可以接受服务器回发的类型为 text/html。
- Accept: */* 代表浏览器可以处理所有类型,(一般浏览器发给服务器都是发这个)。
2.Accept-Encoding
- Accept-Encoding: gzip, deflate 浏览器申明自己接收的编码方法,通常指定压缩方法,是否支持压缩,支持什么压缩方法(gzip,deflate),(注意:这不是只字符编码)。
3.Accept-Language
- Accept-Language:zh-CN,zh;q=0.9 浏览器申明自己接收的语言。
4.Connection
- Connection: keep-alive 当一个网页打开完成后,客户端和服务器之间用于传输HTTP数据的TCP连接不会关闭,如果客户端再次访问这个服务器上的网页,会继续使用这一条已经建立的连接。
- Connection: close 代表一个Request完成后,客户端和服务器之间用于传输HTTP数据的TCP连接会关闭, 当客户端再次发送Request,需要重新建立TCP连接。
5.Host(发送请求时,该报头域是必需的)
- Host:www.baidu.com 请求报头域主要用于指定被请求资源的Internet主机和端口号,它通常从HTTP URL中提取出来的。
6.Referer
- Referer:www.baidu.com/?tn=6209510… 当浏览器向web服务器发送请求的时候,一般会带上Referer,告诉服务器我是从哪个页面链接过来的,服务器籍此可以获得一些信息用于处理。
7.User-Agent
- 告诉HTTP服务器, 客户端使用的操作系统和浏览器的名称和版本。
8.Cache-Control
- Cache-Control:private 默认为private 响应只能够作为私有的缓存,不能再用户间共享
- **\**Cache-Control:public\** **响应会被缓存,并且在多用户间共享。正常情况, 如果要求HTTP认证,响应会自动设置为 private.
- Cache-Control:must-revalidate 响应在特定条件下会被重用,以满足接下来的请求,但是它必须到服务器端去验证它是不是仍然是最新的。
- Cache-Control:no-cache 响应不会被缓存,而是实时向服务器端请求资源。
- Cache-Control:max-age=10 设置缓存最大的有效时间,但是这个参数定义的是时间大小(比如:60)而不是确定的时间点。单位是[秒 seconds]。
- **Cache-Control:no-store **在任何条件下,响应都不会被缓存,并且不会被写入到客户端的磁盘里,这也是基于安全考虑的某些敏感的响应才会使用这个。
9.Cookie
Cookie是用来存储一些用户信息以便让服务器辨别用户身份的(大多数需要登录的网站上面会比较常见),比如cookie会存储一些用户的用户名和密码,当用户登录后就会在客户端产生一个cookie来存储相关信息,这样浏览器通过读取cookie的信息去服务器上验证并通过后会判定你是合法用户,从而允许查看相应网页。当然cookie里面的数据不仅仅是上述范围,还有很多信息可以存储是cookie里面,比如sessionid等。
七、Http Response header (返回头信息)
应答头 | 说明 |
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头中提供什么类型的授权信息? |
常见的媒体格式类型如下:
- text/html : HTML格式
- text/plain :纯文本格式
- text/xml : XML格式
- image/gif :gif图片格式
- image/jpeg :jpg图片格式
- image/png:png图片格式
以application开头的媒体格式类型:
- application/json: JSON数据格式
- application/xhtml+xml :XHTML格式
另外一种常见的媒体格式是上传文件时使用的:
- multipart/form-data : 需要在表单中进行文件上传时,就需要使用该格式
八
划水划完啦。
猜你喜欢
- 2024-12-19 大文件上传服务器:支持超大文件HTTP断点续传的实现办法
- 2024-12-19 Java网络编程 JAVA网络编程案例教程
- 2024-12-19 JDK11的新特性:新的HTTP API jdk11的新特性有哪些
- 2024-12-19 适用于Spring Boot的轻量级 HTTP 客户端框架
- 2024-12-19 不要忽视了它:HTTP 必知必会的那些知识
- 2024-12-19 HttpClient封装,对外提供简化的HTTP请求
- 2024-12-19 Python爬虫常用的三大库(Request的介绍)
- 2024-12-19 面试官:说说 WebSocket 和 Socket 及Http的区别?
- 2024-12-19 Java 发送邮件 java 发送邮件附件名错误
- 2024-12-19 HTTP 和 RPC 的区别 rpc协议和http协议的区别
你 发表评论:
欢迎- 04-27微服务部署架构设计详解(图文全面总结)
- 04-27Java微服务架构选型与对比:一场技术流派的巅峰对决
- 04-27微服务架构下Java的最佳实践
- 04-27Java微服务架构选型:优雅拆分与高效整合
- 04-27微服务架构下的Java代码拆分策略:像拼图一样构建系统
- 04-27微服务架构下的Java最佳实践
- 04-27微服务架构下Java的挑战与机遇
- 04-27微服务架构下Java事务管理的艺术
- 最近发表
- 标签列表
-
- java反编译工具 (77)
- java反射 (57)
- java接口 (61)
- java随机数 (63)
- java7下载 (59)
- java数据结构 (61)
- java 三目运算符 (65)
- java对象转map (63)
- Java继承 (69)
- java字符串替换 (60)
- 快速排序java (59)
- java并发编程 (58)
- java api文档 (60)
- centos安装java (57)
- java调用webservice接口 (61)
- java深拷贝 (61)
- 工厂模式java (59)
- java代理模式 (59)
- java.lang (57)
- java连接mysql数据库 (67)
- java重载 (68)
- java 循环语句 (66)
- java反序列化 (58)
- java时间函数 (60)
- java是值传递还是引用传递 (62)
本文暂时没有评论,来添加一个吧(●'◡'●)