欢迎访问悦橙教程(wld5.com),关注java教程。悦橙教程  java问答|  每日更新
页面导航 : > > 文章正文

[Http协议] 笔记,浏览器只需要请求服务

来源: javaer 分享于  点击 13803 次 点评:172

[Http协议] 笔记,浏览器只需要请求服务


B/S 架构

Browser/Server,浏览器/服务器架构模式,它的特点是,客户端需要浏览器,应用程序的逻辑和数据都存储在服务器端。

浏览器只需要请求服务器,获取Web资源,服务器把Web资源发送给浏览器即可

好处: 易于维护升级。服务器端升级后,客户端无需任何部署就可以使用到新的版本

  • 静态资源: HTML、CSS、JavaScript、图片等,负责页面展现
  • 动态资源: Servlet、JSP等,负责逻辑处理
  • 数据库: 负责存储数据
  • HTTP协议: 定义通信规则
  • Web服务器: 解析协议,解析请求数据,发送响应数据(如:Tomcat)

HTTP超文本传输协议

HTTP就是服务器和浏览器传输信息的格式约定

协议特点

  • 基于TCP: 面向连接、安全
  • 基于请求-响应模型: 一次请求对应一次响应
  • HTTP是无状态的: 对事务处理无记忆能力
    • 缺点:多次请求不能共享数据 (用cookie和session解决)
    • 优点:速度快

请求数据格式

  1. 请求行: 请求方式,资源路径,协议版本
    • GET / HTTP/1.1
  2. 请求头: 第二行开始,key:value格式
  3. 请求体: POST请求的最后一部分,存放请求参数

常见的HTTP请求头:

  • Host: 表示请求的主机名
  • User-Agent: 浏览器版本,例如Chrome浏览器的标识类似Mozilla/5.0 ...Chrome/79,IE浏览器的标识类似Mozilla/5.0 (Windows NT ...)like Gecko;
  • Accept: 表示浏览器能接收的资源类型,如text/,image或者/表示所有;
  • Accept-Language: 表示浏览器偏好的语言,服务器可以据此返回不同语言的网页;
  • Accept-Encoding: 表示浏览器可以支持的压缩类型,例如gzip, deflate等。
POST / HTTP/1.1
Host: www.baidu.com
Connection: keep-alive
Cache-Control: max-age=0 Upgrade-lnsecure-Requests: 1
User-Agent: Mozilla/5.0 Chrome/91.0.4472.106

username=zhangsan&password=123456

请求体和请求头之间有一个空行

请求参数的位置

  • GET发请求参数,放在链接中
  • POST发请求参数,放在请求体中

响应数据格式

  1. 响应行: 协议 状态码 描述

    • HTTP/1.1 200 OK
  2. 响应头: 第二行开始,key:value格式

    • Content-Type: 表示该响应内容的类型,例如text/html,image/jpeg;
    • Content-Length: 表示该响应内容的长度(字节数);
    • Content-Encoding: 表示该响应压缩算法,例如gzip;
    • Cache-Control: 指示客户端应如何缓存,例如max-age=300表示可以最多缓存300秒
  3. 响应体: 存放响应内容


状态码大全

https://cloud.tencent.com/developer/chapter/13553

相关栏目:

用户点评