Homework
Wang yuan can
January 14, 2020
@雨人网安
作业
作业开始
1.作业提要
- 浏览器页面渲染始末
- 渗透测试常用工具
2.作业分析
2.1 从输入 URL 到页面加载完成的过程中都发生了什么事情?
在打开浏览器,然后在输入URL
的时候浏览器显示一些与你输入的内容相匹配的网址,其实我们在浏览器中输入URL
的时候,浏览器就会开始智能的匹配可能URL
,浏览器会从历史记录,书签等地方,找到你已经输入的字符串可能对应的URL
,然后给出智能提示。
在输好URL
后我们会按下Enter
键,浏览器会发起请求,如果URL
是域名而不是IP
地址,将进行域名解析
IP
地址是网络上标识站点的数字地址,为了方便记忆,采用域名来代替IP
地址标识站点地址,域名解析就是域名到IP
地址的转换过程
域名解析按下面的步骤进行:
- 我们本地硬盘下有一个
hosts
(windows
下路径为C:WindowsSystem32driversetc
)文件,作用是将一些常用的网址域名与其对应的IP
地址建立一个关联“数据库”。一般来说,系统会首先自动从hosts
文件中寻找对应的IP
地址,如果有的话就直接使用hosts
文件里面的IP
地址,然后直接进行端口确认 - 如果上一步没有找到,浏览器将调用解析程序,并成为
DNS
服务器的一个客户,把待解析的域名放在DNS
请求报文中,以UDP
用户数据报的方式发给本地DNS
服务器 - 如果本地
DNS
服务器查找到相应的域名的IP
地址,就把对应的IP
地址放在回答报文中返回 -
如果上一步没有找到,即本地
DNS
服务器不知道被查询域名的IP
地址,由于主机向本地DNS
服务器的查询是递归查询,所以此时,本地DNS
服务器就会以DNS
客户的身份向其他根DNS
服务器继续发出查询请求报文。本地DNS
服务器向根DNS
服务器的查询是迭代查询,当找到相应域名的IP
地址后,就会把这个结果返回给最初发起查询请求的浏览器递归查询:在该模式下
DNS
服务器接收到客户机请求,必须返回一个准确的查询结果给客户机。如果该DNS
服务器本地没有存储被查询的DNS
信息,那么该服务器会(替客户机)询问其他服务器,并将返回的查询结果再返回给客户机。迭代查询:在该模式下
DNS
服务器接收到客户机请求,如果该DNS
服务器本地没有存储被查询的DNS
信息,DNS
服务器会向客户机提供其他能够解析查询请求的DNS
服务器地址,让客户机再向这台DNS
服务器提交请求,依次循环直到返回查询的结果为止。 - 经过上面的步骤后,浏览器已经获得输入域名的
IP
地址,可以进行下一步了。
- 浏览器得到
IP
地址后,还要确认一下端口,默认端口是80
端口,一个服务器可能会提供不同的服务,这些服务通过端口来区分,可以指定端口号 -
浏览器得到
IP
地址并确认端口后,会向目标服务器发起HTTP
请求,HTTP
请求是通过TCP
连接来发送的(如果是HTTPS
则需要先建立SSL连接,再是TCP
连接,下面的讨论基于HTTP
),具体如下
浏览器会生成目标服务器的HTTP
请求报文,请求报文一般包含请求方法、请求URI
、协议版本、请求首部字段等内容,HTTP
请求准备好后,HTTP
请求报文从应用层传到传输层后会被分割为报文段,并会发起一条到达目标服务器的TCP
连接,开始TCP
三次握手,过程如图所示:
通俗的可以理解为:
A主动向B打电话:嗨,能听到吗(SYN=1,seq=x),然后A就开始等待B的回答(SYN-SENT状态),此时A不知道B能不能听到
B听到A的话之后,可以确认它能听到A,但是它还要确认一下A能不能听到他自己的声音,于是B说:我能听到你的声音(ACK=1,ack=x+1),你能听到我的声音吗(SYN=1,seq=y),然后B开始等待A的恢复(SYN-RECD状态)
A听到B的话之后,A可以确认两件事,一是B能听到它说话,二是它也能听到B说话,A已经可以随时说话和倾听了(ESTABLISHED状态)。但是此时的B还在等待中,并不知道A能不能听到,所以此时A需要再回复B说:我可以听到你的声音(ACK=1,ack=y+1),开始愉快的聊天吧~(seq=x+1),B听到这句话后便也可以随时说话和倾听了(ESTABLISHED状态)
之后两个人就可以balabalabala....
HTTP
请求的请求报文是直接附在第三次握手的消息中
穿插补充小知识,为什么是三次握手,而不是两次四次?
有一种观点是三次握手是基于TCP
协议的可靠性(Reliability
)要求,这是确认双发都能进行收发的最小次数,两次确认不了,四次多余。但是并没有完全意义上的可靠,不论握手多少次都只能表明握手的时候是可靠的,不能保证后面数据传输时一直可靠,因为信道是不可靠的,当然三次握手至少可以表明它曾经可靠,这是两次握手无法完成的,而四次甚至更多次握手仅仅是提高“它曾经可靠”这个结论的可信程度。所以这个握手也只是确保可靠的一个基本需要,TCP
协议的可靠性(注意区分完整性integrity
)更多的是由校验和、定时器超时重传、确认机制在《计算机网络》一书中也有讲过这个问题,给出的解释是:三次握手是为了防止失效的连接请求报文段被服务端接收,从而产生错误。具体例子如下所述:
client
发出的一个连接请求报文段并没有丢失,而是在某个网络结点长时间的滞留了,以致延误到连接释放以后的某个时间才到达server
。本来这是一个早已失效的报文段。但server
收到此失效的连接请求报文段后,就误认为是client
再次发出的一个新的连接请求。于是就向client
发出确认报文段,同意建立连接。
假设不采用“三次握手”,那么只要server
发出确认,新的连接就建立了。但是由于现在client
并没有发出建立连接的请求,因此不会理睬server
的确认,也不会向server
发送数据。而server
却以为新的连接已经建立,并一直等待client
发来数据。这样,server
的很多资源就白白浪费掉了。
采用“三次握手”的办法可以防止上述现象发生。例如刚才那种情况,client
不会向server
的确认发出确认。server
由于收不到确认,就知道client
并没有要求建立连接
连接建立之后,开始进行数据传输,虽然浏览器知道目标服务器的IP
和端口,但是数据总不可能飞过去吧?HTTP
请求报文段会从传输层传到网络层,在网络层被封装成IP
数据包,网络层规定了通过怎样的路径(所谓的传输路线)到达目标服务器,并把数据包传送给对方。
网络层封装好的IP
数据包会进一步传到下一层 --- 数据链路层,然后会再次被封装到MAC
数据帧结构中,由于IP
地址间的通信依赖于MAC
地址(网卡所属的固定地址),所以MAC
数据帧结构中会有经过ARP
协议解析后的MAC
地址(不一定是目标服务器的MAC
地址,因为实际上通信的双方在同一局域网(LAN)内的情况是很少的,一般都会经过路由中转)。
数据链路层的MAC
数据帧再向下传,便会到达物理层,这里要注意物理层考虑的是怎样才能在连接各种计算机的传输媒体上传输数据比特流,而不是指具体的传输媒体。 物理层需要确保原始的数据可在各种物理媒体上传输,它规定了传输媒体的机械特性、电气特性、功能特性、过程特性:
常见的传输媒体有双绞线、电缆、光缆、无线信道等,物理层的任务就是要让数据在这些传输媒体上都能能进行传输
通过MAC
地址匹配,数据通过传输媒体到达目标服务器的物理层,物理层接收数据比特流然后向上传送到服务器的数据链路层,在数据链路层MAC
数据帧将进行封装的逆操作,还原成IP
数据包之后向上传送到网络层,网络层也进行封装的逆操作还原成HTTP
请求报文段(分割后的一小段一小段的),然后这些报文段向上传到传输层,在传输层按原来的序号重新组装成完整的HTTP
请求报文,再向上传到应用层,应用层的HTTP
协议便会开始对请求进行处理
这个处理可能是直接返回静态的资源,也可能经过PHP
、JAVA
等语言进行处理等,等处理完成后,会返回一个HTTP
响应,它生成一个HTTP
响应报文,与HTTP
请求报文结构类似,然后这个响应报文会“走过”请求报文来时的路到达浏览器
浏览器接收HTTP
响应,然后有可能释放TCP
连接,也有可能重新使用这个TCP
连接发送新的请求(持久连接),此处了解一下TCP
连接的释放,不同于TCP
连接建立的三次握手,TCP
连接的释放是四次挥手,客户端和服务器端都可以发起关闭请求,也存在两者同时发起关闭请求的情况,图中为客户端A主动发起关闭请求:
同样通俗的解释一波:
A对B要传的文件已经传完了,于是他对B说:我要传的文件已经传完了,我要准备下线了(seq=u,FIN=1)。然后A就等待B的回复(FIN-WAIT-1状态)
B看到A的消息后,回复A说:知道了,但是我还有文件给你(ACK=1,ack=u+1,seq=v)。B进入等他文件传完的状态(CLOSE-WAIT状态)。
A收到B的回复之后,下线不了了,于是继续等待着B的文件传完(FIN-WAIT-2状态)
几分钟后,B的文件传完了,此时他对A说:我的文件传完了,我也要下线了(seq=w,FIN=1,ACK=1,ack=u+1),然后B等待A的回复来确认真的可以下线了(LAST-ACK状态)
A收到B的回复后,便对A说:好的,那你下线吧(ACK=1,seq=u+1,ack=w+1)。此时A会等待一段时间(2MSL,TIME-WAIT状态),B收到后就直接下线了(CLOSE状态),然后2MSL时间到了之后,A也下线(CLOSE状态)
为什么服务器B在接到A的断开请求时不立即同意断开?
当服务器B收到断开连接的请求时,服务器可能仍然有数据未发送完毕,所以服务器先发送确认信号,等所有数据发送完毕后再同意断开
为什么是四次挥手,而不是像建立连接一样的三次
因为TCP
连接是全双工模式,服务器B收到A的断开请求时,仅仅表明A没有东西传给服务器B了,但此时服务器B可能向A的传输还没结束,所以服务器B要先给A一个确认收到A的断开请求的ACK
报文,然后继续向A把信息传完,等传完之后服务器B再向A发送断开请求的报文段,等A收到并回复ACK
报文后再释放连接。
也就是说对于A来说他要发送请求给B并等待B确认,对于B来说也要发送请求给A并等待A确认,两者都经过这两个过程才能完全释放TCP
连接,而非单方面的释放。
建立连接只需要建立,没有数据的影响,而释放连接还要考虑数据是否传输完,所以建立连接的时候B确认收到A的建立请求与B发送建立请求这一步可以合成一步成为TCP
建立连接的第二次握手,而释放连接时却必须分开。
最后一次握手后A为什么要等2MSL
?
首先解释一下MSL
,MSL
是指最长报文段寿命,RFC793建议为两分钟,但实际上可据实际情况而定,也就是说一个报文段最久可存在的时间是MSL
这是为了保证A发送的最后一个ACK
报文能够到达服务器B,如果这个ACK
报文丢失了,服务器B没有收到,B会超时重传第三次握手的FIN+ACK
报文给A,这个时候处于等待的A就可以收到这个重传的FIN+ACK
报文,并再次发送ACK
报文给服务器B,并且重新启动2MSL计时器,最终结果是A和B都正常进入CLOSE状态。如果A发完ACK
报文后就直接释放了A-->B的连接,那么A就收不到B重传的FIN+ACK
报文,也不能重新发送ACK`报文,那么B就无法按正常步骤释放B-->A的连接
防止“已失效的连接请求报文”出现在下一个新的连接中,因为一个报文段的寿命是MSL
,所以A在发送完最后一个ACK
报文段之后,再经过时间2MSL
,本连接持续的时间内所产生的所有报文段都将在网络中消失,这样这些旧的报文段便不会出现在下一个新的连接中
浏览器之后会检查HTTP
的响应状态,主要通过响应码来判断
1xx: 表示通知信息的,比如请求收到了或正在处理
2xx:表示成功,操作被成功接收并处理
3xx:表示重定向,一般完成请求还必须采取进一步的行动
4xx:表示客户端的差错
5xx:表示服务器的差错
如果响应可缓存,浏览器将把响应存入缓存
浏览器根据HTTP
报头信息解码响应,决定如何处理这些响应,并展现响应,以响应为一个HTML
为例
浏览器开始自上而下,自左而右的加载HTML
文档,最开始会遇到<!DOCTYPE>
声明,然后根据<!DOCTYPE>
声明浏览器就知道该用哪种规范来解析这个文档
再继续边加载边解析,边生成DOM
树,加载过程中遇到外部CSS
文件,浏览器便会另外发出一个请求,来获取CSS
文件(过程和上面说的一样),获取CSS
后会生成CSS Rule
树。DOM
树和CSS Rule
树生成Render
树,页面可以开始边加载边渲染了
渲染树和DOM
树的关系:那些不可见的DOM
元素(如<head>…</head>
,display=none
的元素)不会被插入渲染树中;还有像一些节点是绝对定位或浮动,这些节点会在文本流之外,因此他们会在渲染树和DOM
树的不同位置,渲染树标识出真实的位置,并用一个占位结构标识出他们原来的位置,而DOM
树上是他们原来的位置
渲染包含"布局"(layout
)和"绘制"(paint
)这两个步骤,所谓"布局"是指给出每个DOM
节点在浏览器窗口中的准确位置,"绘制"是指遍历Render
树将布局好的DOM
节点绘制在屏幕上。
-
浏览器继续加载渲染,如果遇到
<script>
标签,浏览器会立即执行(暂不考虑defer
及async
属性),此时会出现页面阻塞,不仅要等待文档中JS
文件下载加载完毕,还要等待JS
解析执行完毕,才可以恢复HTML
文档的加载解析。- 这是浏览器为了防止出现
JS
修改DOM
树,需要重新构建DOM
树的情况,DOM
树改变浏览器需要回过头来重新渲染这部分代码,所以浏览器希望通过阻塞其他内容的下载和呈现,来避免出现更多的不必要的Reflow
(称为回流或者重排) - 如果
<script>
放在的<head>
中,则<body>
标签无法被加载,那么页面自然就无法渲染了,因此这将导致在该JS
代码完全执行完之前,页面都是一片空白,用户体验非常不好,一般我看到长时间的空白页面,我都非常想直接关闭它。因此会推荐将所有<script>
标签尽可能放到<body>
标签的底部,以尽量减少对整个页面下载的影响,此时虽然还会存在一个脚本阻塞另一个脚本的问题,但是用户体验比上面的好很多,因为用户看到了大部分内容,而不是空白 defer
属性相当于告诉浏览器立即下载,延迟执行。它使得加载后续文档元素的过程将和JS
文件的加载并行进行(异步),但是JS
文件的执行要在整个页面解析完成之后,DOMContentLoaded
事件触发之前完成,执行顺序为出现的先后顺序。(高程中指出现实中不一定会按照顺序执行,也不一定会在DOMContentLoaded
事件触发之前完成,因此最好只包含一个延迟脚本,这可能是与浏览器的实现有关,具体什么情况下会出现我还不知道???)async
属性相当于告诉浏览器立即下载执行,并且页面的加载渲染不需要等待该脚本加载和执行,它们两者会异步进行。标记为async
的脚本不会按照它们出现的先后顺序执行,而是谁先下载完了谁就先执行,它们一定会在页面的load
事件触发之前执行,但可能会在DOMContentLoaded
事件触发之前或之后执行。基于前面所说的一点原因,异步脚本最好不要修改DOM
,如果由多个异步脚本,它们之间最好没有依赖关系
- 这是浏览器为了防止出现
- 浏览器继续加载渲染,如果遇到图片资源,浏览器也会另外发出一个请求,来获取图片资源,这是异步请求,所以不会等到图片下载完,而是继续渲染后面的
HTML
文档。 - 等到服务器返回图片文件,如果先前并没有为这个图片设定宽高,那么由于图片占用了一定面积,影响了后面段落的排布,浏览器会进行
Reflow
- 然后然后终于和
</html>
碰面了,此次的页面加载渲染过程完成,浏览器也是很累了,然后会立即触发DOMContentLoaded
事件,该事件是在形成完整的DOM
树之后就会触发,而不会理会图像、JS
文件、CSS
文件或其他资源是否已经下载完毕 - 当页面完全加载后,也就是所有图像、
JS
文件、CSS
文件等外部资源都加载完成后会触发load
事件 -
用户在页面上进行交互时,可能会导致页面进行
Repaint
或Reflow
Repaint
:如果只是改变了某个元素的背景颜色,文字颜色等,不影响元素周围或内部布局的属性,将只会引起浏览器的Repaint
,重绘某一部分Reflow
:如果某个部分发生了的变化影响了布局,那浏览器就需要倒回去重新渲染,每次Reflow
必然会导致Repaint
2.2 整理收集渗透测试常用工具(信息收集,抓改包,webshell,注入,编解码,代理,扫描,漏洞利用)
需要做:给出相应类型工具无后门版下载地址
介绍:简单介绍该工具如何使用,或者给出官方手册或者互联网上比较好的教程文章
拓展:动手用一下这些工具
2.2.1 信息收集类
- nmap
下载地址:https://nmap.org/download.html
在kali虚拟机中自带nmap,可通过nmap指令利用nmap
如,启动nmap:
>nmap
如,启动zenmap
>zenmap
nmap常用参数解析表
参数 |
说明 |
-sT |
TCP扫描,这种方式会在目标主机的日志中记录大批连接请求和错误信息 |
-sS |
半开扫描,很少有系统能够把它记入系统日志。但需要root权限 |
-sF -sN |
秘密FIN数据包扫描、XmasTree、Null扫描模式 |
-sP |
Ping扫描,Nmap在扫描端口时,默认都会使用ping扫描,只有主机存活,Nmap才会继续扫描 |
-sU |
UDP扫描, |
-sA |
高级扫描方法,通常用来穿过防火墙的规则集 |
-sV |
探测端口服务版本 |
-P0 |
扫描之前不用ping命令,防火墙禁止ping的时候,可以使用此选项进行扫描 |
-v |
显示扫描结果 |
-h |
帮助文档 |
-p |
指定扫描的端口范围 |
-O |
启动远程操作系统检测 |
-A |
全面系统检测、启动脚本检测、扫描等 |
-oN/-oX/-oG |
将报告写入文件,分别是正常、XML grepable三种模式 |
-T4 |
针对TCP端口禁止动态扫描延迟超过10ms |
-iL |
读取主机列表 |
- 御剑
- Google Hacking(GitHack)
下载地址:(Github)https://github.com/lijiejie/GitHack
- Matlego
可使用Linux Kali的Maltego
官方地址:https://www.paterva.com/buy/maltego-clients/maltego-ce.php
- Whois
下载地址:(吾爱破解)https://www.52pojie.cn/thread-864451-1-1.html
2.2.2 漏洞扫描类
- AWVS
下载地址:(吾爱破解)https://www.52pojie.cn/thread-1036610-1-1.html
- H3C WebScan
- Appscan
下载地址:(吾爱破解)https://www.52pojie.cn/thread-992186-1-1.html
- NetSparker
下载地址:(吾爱破解)https://www.52pojie.cn/thread-993030-1-1.html
- Nessus
下载地址:(吾爱破解)https://www.52pojie.cn/forum.php?mod=viewthread&tid=702905&fromguid=hot
或用Bai的虚拟机内置版
2.2.3 漏洞利用类
- 中国菜刀
下载地址:(官网)http://www.zhongguocaidao.net/
- Sqlmap
下载地址:(Github)https://github.com/sqlmapproject/sqlmap
- 穿山甲
下载地址:(吾爱破解)https://www.52pojie.cn/forum.php?mod=viewthread&tid=861759
- Struts2终极漏洞利用工具
下载地址:(吾爱破解)https://www.52pojie.cn/thread-888314-1-1.html - Seay-van源码泄露漏洞利用工具
下载地址:http://www.vuln.cn/2225
- Antsword(中国蚁剑)
下载地址:(Github)https://github.com/AntSwordProject/
安装教程:https://www.fujieace.com/hacker/tools/antsword.html
注意需要下载一个antsword和一个加载器:
- Behinder(中国冰蝎)
下载地址:(Github)https://github.com/rebeyond/Behinder
2.2.4 综合平台类
- Burpsuite v2.1.07
下载地址:(吾爱破解)https://down.52pojie.cn/Tools/Network_Analyzer/Burp_Suite_Pro_v2.1.07_Loader_Keygen.zip
注意:需要将两个文件移动到jdk8的/bin目录下,然后用命令启动Burpsuite破解(需要移动的两个文件如下图)
- Metasploit
下载地址:
(Windows版,官网)https://windows.metasploit.com/metasploitframework-latest.msi
Linux kali自带msf,可在终端用msfconsole命令启动
3.思考总结
url地址解析到浏览器页面渲染完成的过程着实复杂,包含了计算机网络大部分的重要知识,小小的一个动作完成了这么多的工作,不禁让人感叹科技的力量。今天在渗透测试方面又接触了一堆工具,一切还在持续积累中。
4.参考资料
Linux kali探测以及nmap初体验:https://www.cnblogs.com/wangyuyang1016/p/10905326.html
网络安全工具大全:https://sectools.org
CTF工具包:https://cloud.tencent.com/developer/article/1352450
Kali Linux Maltego情报收集工具:https://www.cnblogs.com/zh2000/p/11199492.html
计算机网络基础知识:https://hit-alibaba.github.io/interview/basic/network/HTTP.html
浏览器如何工作:https://www.html5rocks.com/en/tutorials/internals/howbrowserswork/
Burpsuite使用指南:https://t0data.gitbooks.io/burpsuite/content/
从输入URL到页面加载完成都发生了什么事情?https://segmentfault.com/a/1190000014620172