页面访问过程及get/post的理解——

  1. Chrome查看开发者工具面板,常看的一些数据?

Elements:查找网页源代码HTML中的任一元素,手动修改任一元素的属性和样式且能实时在浏览器里面得到反馈。

Console:记录开发者开发过程中的日志信息,且可以作为与JS进行交互的命令行Shell。

Sources:断点调试JS。

Network:从发起网页页面请求request后分析HTTP请求后得到的各个请求资源信息(包括状态,资源类型,大小,所用时间等),可以根据这个进行网络性能优化。

Timeline:记录分析在网站的生命周期内所发生的各类事件,以此可以提高网页的运行时间的性能。

Performance:记录JS,CPU执行时间细节,可以录制过程。

Application:记录网站加载的所有资源信息,包括存储数据(Local Storage,Session Storage,IndexedDB,Web SQL,Cookies)、缓存数据、字体、图片、脚本、样式表等。

Security:判断当前页面是否安全。

Audits:对当前网页进行网络利用情况、网页性能方面的诊断,并给出一些优化建议。比如列出所有没有用到的CSS文件等。

  1. 一个web页面的访问过程?

用户在浏览器输入url,比如http://sina.com,那么接下来:

①浏览器首先会查询本机的系统来获取主机名对应的IP地址;

②若本机查询不到相应的IP地址,则会发起DNS请求,获取主机名对应的IP地址;

③使用查询到的IP地址,直接访问目标服务器。

首先说说访问目标地址的两种方式:

第一,使用目标IP地址访问。比如你可以直接在浏览器中输入新浪的IP地址:218.30.13.36来直接访问它的主机;

第二,由于IP地址都是一堆数字不方便记忆,于是有了域名这种字符型标识。DNS服务器则完成域名解析的工作,它将你访问的目标域名转换成相应的IP地址。

因此若你的电脑上不了网未必就一定是目标主机的问题,还可能是DNS服务器的故障。所以这种情况下,你能熟知几个常用的IP地址,那么在命令行使用ping一下就能知道问题是否是出现在了DNS服务器上了。比较常用的IP有:百度180.76.76.76,谷歌8.8.8.8或阿里云223.5.5.5

为什么我们不能自己建立一个www.sina.com网站,让全世界的人都访问我的这个网站呢?由以上几步可以看出,因为域名系统的存在,使得我们可以访问目标域名(www.sina.com)的时候,DNS服务器总是解析对应的IP地址(218.30.13.36)。所以若要别人都访问你的“新浪”,则需要将DNS的服务器路径指向你本机所在的IP地址,这显然得新浪愿意才行。

④浏览器发送HTTP请求。

HTTP请求由三部分组成,分别是:请求行、消息报头、请求正文。

⑤从请求消息中获得客户机想访问的主机名。

⑥从请求信息中获取客户机想要访问的web应用。(web应用程序指提供浏览器访问的程序,简称web应用)

⑦从请求信息中获取客户机想要访问的web资源。(web资源,即各种文件,图片,视频,文本等)

⑧读取相应的主机下的web应用,web资源。

⑨用读取到的web资源数据,创建一个HTTP响应。

⑩服务器回送HTTP响应。

HTTP响应也是由三个部分组成,分别是:状态行、消息报头、响应正文。

?客户浏览器解析回送的资源,并显示结果。

  1. HTTP协议详解:

HTTP(Hyper Text Transfer Protocol)超文本传输协议,目的是保证浏览器与服务器之间的通信。HTTP的工作方式是客户端与服务器之间的请求-应答协议。是一个属于应用层的面向对象的协议,由于其简捷、快速的方式,适用于分布式超媒体信息系统。

HTTP协议的主要特点概括如下:

①支持客户/服务器模式;

②简单快速:客户向服务器请求服务时,只需传送请求方法和路径。请求方法常用的有GET,POST,PUT.DELETE。每种方法规定了客户与服务器练习的类型不同。由于HTTP协议简单,使得HTTP服务器的程序规模小,因而通信速度快。

③灵活:HTTP允许传输任意类型的数据对象。正在传输的类型由Content-Type加以标记。

④无连接:无连接的含义是限制每次连接只处理一个请求,服务器处理完客户的请求,并收到客户的应答后,即断开连接。,采用这种方式可以节省传输时间。

⑤无状态:HTTP协议是无状态协议。无状态是指协议对于事务处理没有记忆功能。缺少状态意味着如果后续处理需要前面的信息,则它必须重传,这样可能导致每次连接传送的数据量增大。另一方面,在服务器不需要先前信息时它的应答就较快。

  1. Get与Post区别?

HTTP是基于TCP/IP的关于数据如何在万维网中通讯的协议。HTTP的底层是TCP/IP,所以GET和POST的底层也是TCP/IP,也就是说GET/POST都是TCP链接,他们能做的事是一样的。他们最大的区别是GET产生一个TCP数据包,POST产生两个TCP数据包。具体来说,对于GET请求,浏览器会把http header和data一并发送出去,服务器相应200(返回数据);而对于POST,浏览器先发送header,服务器响应100 continue,浏览器再发送data,服务器响应200 OK(返回数据)。据研究,在网络环境好的情况下,发一次包的时间和发两次包的时间差别基本上可以无视。而在网络差的情况下,两次包的TCP在验证数据包完整性上,有非常大的有点。另外,并不是多有的浏览器都会在post中发送两次包,Firefox就只发一次。

Get请求的参数写在url中,传输的参数安全性低,传输的数据大小有限制,不超过2KB、GET方式服务器端用request.QueryString获取变量的值。

Post方式将表单内各字段和内容放在HTML HEADER中一起传送到action属性所指定的URL地址,用户看不到这个过程、传送的数据量比较大、传输的数据安全性较高、POST方式在服务器端用Request.Form获取提交的数据。

通常,get用于从服务器获取数据,post用于向服务器提交数据。

原文地址:https://www.cnblogs.com/fancyl/p/9855570.html

时间: 2024-08-07 04:06:20

页面访问过程及get/post的理解——的相关文章

【IIS】我所理解的IIS处理ASP.NET页面请求过程

众所周知,一个完整的动态网页的从请求到响应无非包括以下3个步骤: 1.浏览器客户端发出http请求. 2.IIS服务端接受请求. 3.处理请求并输出请求结果到浏览器客户端. 首先,简单的说说我所理解的IIS,它依赖于Windows服务World Wide Web Publish Service的,并依赖于进程w3wp.exe的.也就是说IIS的运行离不开工作进程w3wp.exe,同时每个IIS站点下的应用程序都是被用用程序池进行隔离,应用程序池即w3wp.exe的容器,通过池隔离的机制保证当某个

面向过程和面向对象的本质理解

http://kiritor.blog.51cto.com/7400479/1226762/ 面向过程和面向对象的本质理解 面向过程就是分析出解决问题所需的步骤,面向对象则是把构成问题的事物分解成对象,抽象 出对象的目的并不在于完成某个步骤,而是描述其再整个解决问题的步骤中的行为. 面向过程的思维方式是分析综合,面向对象的思维方式是构造. 例如c语言解决问题时,一般是先定义数据结构,然后在构造算法.而是用Java面向对象求解时 则是先抽象出对象,构造一个"封闭"的环境,这个环境中有定义

HTML5移动开发之路(51)——jquerymobile中改善页面访问速度

本文为 兄弟连IT教育 机构官方 HTML5培训 教程,主要介绍:HTML5移动开发之路(51)--jquerymobile中改善页面访问速度 在使用jQuery Mobile进行开发的时候可以选择单页模版和多页模版,在使用单页模版的时候从一个页面跳转到另一个页面的时候需要从服务器请求,用户会感到略有停顿.使用多页模版,可以改善页面跳转之间的流畅性,但是多个页面要一次性下载,所以下载时间变长,用户体验也会受到影响. 在基于预取技术的开发中,当第一个页面的DOM对象加载完成后,jQuery Mob

浏览器渲染页面的过程,以及重绘与重排

浏览器的渲染过程 1,浏览器解析html源码,然后创建一个 DOM树.在DOM树中,每一个HTML标签都有一个对应的节点,并且每一个文本也都会有一个对应的文本节点.DOM树的根节点就是 documentElement,对应的是html标签. 2,浏览器解析CSS代码,计算出最终的样式数据.对CSS代码中非法的语法她会直接忽略掉.解析CSS的时候会按照如下顺序来定义优先级:浏览器默认设置,用户设置,外链样式,内联样式,html中的style. 3,构建出DOM树,并且计算出样式数据后,下一步就是构

提高 SharePoint 页面访问速度之 IIS 应用池回收

相信大家都有这样的体会,我们企业内部的 SharePoint 在使用了一段时间之后,都会有访问速度降低,页面访问速度缓慢的问题,除了服务器硬件瓶颈所导致的原因, 还有一些其他的原因,这些原因从各个层面对SharePoint 造成很多的干扰,今天我们就来说其中的一个,IIS应用池回收. SharePoint 在长期的运行过程当中,服务器内存中会存储很多缓存信息,以帮助下次用户访问时能够快速响应,但是这样的日积月累,也使得内存池承受了很大的压力, 从而形成臃肿的缓存区,那么为了减小服务的负担,IIS

angularjs中的页面访问权限设置

11月在赶一个项目,这阵子比较忙,挤挤时间更一篇博客吧,如标题所述说说在ng中页面访问权限控制的问题,水平有限各位看官见谅: 在以往的项目中,前后端常见的配合方式是前端提供页面和ui加一点DuangDuangDuang的效果,后端搭建框架数据结构和数据交互(数据交互前后端有交集),不管是.net.java or php都能一对多的提供前端服务,然而在新形式下项目中运用了前端框架,开发情况就不一样了,比如我要说的这是在angular框架下完成的开发,模式是后端提供服务和api文档,页面和数据交互及

在浏览器打开网站地址到回车发送请求到看到页面的过程

问题:在浏览器打开某个网站地址到回车发送请求到看到页面的过程? 我们每天都在浏览网页,但是当我们在地址栏输入某个网站的域名后,究竟后台做了哪些工作,发生了什么?一直感到疑惑,故查阅了许多相关的系统资料和网络方面的资料,本人理解总结经过了以下5个过程,写的不完整请补充,谢谢:言归正传. 1.DNS解析流程: 本地缓存和本机host文件---如果找不到则寻找本地网卡设置的DNS(local dns)----从全球13台根域服务器查找,进行逐一递归或者迭代找到相应的服务器资源位置:2.TCP三次握手:

小强的HTML5移动开发之路(51)——jquerymobile中改善页面访问速度

在使用jQuery Mobile进行开发的时候可以选择单页模版和多页模版,在使用单页模版的时候从一个页面跳转到另一个页面的时候需要从服务器请求,用户会感到略有停顿.使用多页模版,可以改善页面跳转之间的流畅性,但是多个页面要一次性下载,所以下载时间变长,用户体验也会受到影响. 在基于预取技术的开发中,当第一个页面的DOM对象加载完成后,jQuery Mobile会对标记data-prefetch的链接地址进行预取操作.预取的详细过程如下: 注意:使用预取功能时,不建议给所有链接都添加data-pr

你刚在淘宝上买了一件衣服---详细解析技术流程(淘宝首页显示一个页面的过程)

声明:文章是之前在网络中看到并保存在电脑里的文档,原地址也无从找到.在此声明.向互联网工程师致敬! 你发现快要过年了,于是想给你的女朋友买一件毛衣,你打开了www.taobao.com.这时你的浏览器首先查询DNS服务器,将www.taobao.com转换成ip地址.不过首先你会发现,你在不同的地区或者不同的网络(电信.联通.移动)的情况下,转换后的IP地址很可能是不一样的,这首先涉及到负载均衡的第一步,通过DNS解析域名时将你的访问分配到不同的入口,同时尽可能保证你所访问的入口是所有入口中可能