开发者社区> 萌璐琉璃> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

[网络基础] Web请求与响应

简介: Web请求过程 浏览器得到主机域名,举例:www.baidu.com 浏览器将域名解析成IP地址 浏览器缓存→系统缓存→路由器缓存→ISP DNS缓存→从根域名服务器递归搜索 浏览器用ip和随机端口号(默认80)连接服务器 浏览器与服务器建立TCP连接(IP:80) 发起 GET 请求 服务器收到请求,发送响应 浏览器获取服务器返回的数据(HTML代码),进行解析和显示 释放TCP连接(不一定) HTTP报文 HTTP报文分为请求报文和响应报文两类。
+关注继续查看

Web请求过程

  1. 浏览器得到主机域名,举例:www.baidu.com

  2. 浏览器将域名解析成IP地址
    浏览器缓存→系统缓存→路由器缓存→ISP DNS缓存→从根域名服务器递归搜索

  3. 浏览器用ip和随机端口号(默认80)连接服务器

    • 浏览器与服务器建立TCP连接(IP:80)
    • 发起 GET 请求
    • 服务器收到请求,发送响应
    • 浏览器获取服务器返回的数据(HTML代码),进行解析和显示
    • 释放TCP连接(不一定)

HTTP报文

HTTP报文分为请求报文和响应报文两类。请求报文和响应报文都由三个部分组成。

  1. 开始行
    用于区别是请求报文还是响应报文,在请求报文中开始行叫做请求行(Request-Line),在响应报文中开始行叫做状态行(Status-Line)。
    请求行的组成由“三个内容” 组成,即:方法、请求资源的URL、HTTP版本,三个内容之间用空格隔开

  2. 首部行
    用来说明浏览器、服务器和报文主体的一些信息,首部行可以是好几行也可以没有。 在每一个首部行中都有首部字段名和它的值,每一行结束的地方要
    有”回车“和”换行“。整个首部结束时,还有一个空行将首部行和后面的实体主体区别开。

  3. 实体主体(一般不使用)

请求报文实例

img_3d4bfccb5296ba2b8472faca57e362cc.png
  • 请求网址
    http://xxx.xxx.xxx.xx:8080/bms/

  • GET /bms/ HTTP/1.1
    请求行,请求方法、请求资源URL(使用相对URL)、HTTP版本

  • Host: xxx.xxx.xxx.xx:8080
    首部行由此开始,Host为主机域名。举例:浏览器输入http://www.baidu.com,则显示 www.baidu.com

  • Connection: keep-alive
    keep-alive表明浏览器告诉服务器发送完响应后仍然保持连接。如果为close则发送完就释放连接

  • Upgrade-Insecure-Requests: 1
    对应服务器的响应头的Content-Security-Policy: upgrade-insecure-requests。是告诉服务器,自己支持这种操作,也就是我能读懂你服务器发过来的上面这条信息,并且在以后发请求的时候不用http而用https。
    参考:chrome浏览器请求头中“Upgrade-Insecure-Requests:1”表示什么意思?

  • User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/65.0.3325.181 Safari/537.36
    表示用户使用的浏览器类型和版本

  • Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,/;q=0.8
    浏览器能够处理的内容类型

  • DNT: 1
    Chrome浏览器开启 随浏览流量一起发送”不跟踪”请求 后会增加此字段
    参考:【HTTP】客户端识别与cookie机制

  • Accept-Encoding: gzip, deflate
    浏览器可以支持的编码。
    gzip 实体采用GNU zip编码
    deflate 用zlib格式压缩
    参考:http中的字符编码

  • Accept-Language: zh-CN,zh;q=0.9
    浏览器支持的语言

响应报文实例

img_7193e70138c49f87a2136bbc5a5ae442.png
  • 响应状态码

    • 1xx : 表示通知信息,如接受到了或是正在处理
    • 2xx :表示成功,如接受到了或是知道了
    • 3xx :表示重定向
    • 4xx :表示客户端错误,如请求的URL不正确
    • 5xx :表示服务器的错误,如服务器压力过大无法完成请求响应
  • Content-Type: text/html;charset=ISO-8859-1
    文档属于什么MIME类型

  • Content-Length: 61
    文档行数

  • Set-Cookie: JSESSIONID=8403645BCCA80AC2F4E28D61ECE7361F; Path=/bms; HttpOnly
    有HttpOnly则cookie不可通过js访问

其他

HTTP(Hyper Text Transfer Protocol)

参考:HTTP协议介绍

  • HTTP是无状态的
    同一个用户第二次访问同一个服务器上的页面时,服务器响应与第一次被访问时的相同

  • HTTP是无连接的
    通信的双方在交换HTTP报文之前不需要先建立HTTP连接。注意与浏览器和服务器建立TCP连接的区别。

参考

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
+关注
萌璐琉璃
Java web 开发者
文章
问答
文章排行榜
最热
最新
相关电子书
更多
WEB浏览器中即将发生的安全变化
立即下载
Web应用系统性能优化
立即下载
边缘安全,让Web加速有保障
立即下载