小编解答:渗透测试七个步骤

   今天我们来聊聊[渗透测试七个步骤],以下3个是关于渗透测试七个步骤的观点,希望能帮助到您找到想要的,更多相关的资讯继续关注本站。

  提问一:渗透测试应该怎么做呢?

  本文贡献者:【繁华乱世沧桑了谁容颜ゝ】 ,解答(渗透测试七个步骤)的问题,如果问题解决,可以关注本站!

  答01、信息收集

  1、域名、IP、端口

  域名信息查询:信息可用于后续渗透

  IP信息查询:确认域名对应IP,确认IP是否真实,确认通信是否正常

  端口信息查询:NMap扫描,确认开放端口

  发现:一共开放两个端口,80为web访问端口,3389为windows远程登陆端口,嘿嘿嘿,试一下

  发现:是Windows Server 2003系统,OK,到此为止。

  2、指纹识别

  其实就是网站的信息。比如通过可以访问的资源,如网站首页,查看源代码:

  看看是否存在文件遍历的漏洞(如图片路径,再通过…/遍历文件)

  是否使用了存在漏洞的框架(如果没有现成的就自己挖)

  02、漏洞扫描

  1、主机扫描

  Nessus

  经典主机漏扫工具,看看有没有CVE漏洞:

  2、Web扫描

  AWVS(Acunetix | Website Security Scanner)扫描器

  PS:扫描器可能会对网站构成伤害,小心谨慎使用。

  03、渗透测试

  1、弱口令漏洞

  漏洞描述

  目标网站管理入口(或数据库等组件的外部连接)使用了容易被猜测的简单字符口令、或者是默认系统账号口令。

  渗透测试

  ① 如果不存在验证码,则直接使用相对应的弱口令字典使用burpsuite 进行爆破

  ② 如果存在验证码,则看验证码是否存在绕过、以及看验证码是否容易识别

  风险评级:高风险

  安全建议

  ① 默认口令以及修改口令都应保证复杂度,比如:大小写字母与数字或特殊字符的组合,口令长度不小于8位等

  ② 定期检查和更换网站管理口令

  2、文件下载(目录浏览)漏洞

  漏洞描述

  一些网站由于业务需求,可能提供文件查看或下载的功能,如果对用户查看或下载的文件不做限制,则恶意用户就能够查看或下载任意的文件,可以是源代码文件、敏感文件等。

  渗透测试

  ① 查找可能存在文件包含的漏洞点,比如js,css等页面代码路径

  ② 看看有没有文件上传访问的功能

  ③ 采用…/来测试能否夸目录访问文件

  风险评级:高风险

  安全建议

  ① 采用白名单机制限制服务器目录的访问,以及可以访问的文件类型(小心被绕过)

  ② 过滤【./】等特殊字符

  ③ 采用文件流的访问返回上传文件(如用户头像),不要通过真实的网站路径。

  示例:tomcat,默认关闭路径浏览的功能:

  <param-name>listings</param-name>

  <param-value>false</param-value>

  3、任意文件上传漏洞

  漏洞描述

  目标网站允许用户向网站直接上传文件,但未对所上传文件的类型和内容进行严格的过滤。

  渗透测试

  ① 收集网站信息,判断使用的语言(PHP,ASP,JSP)

  ② 过滤规则绕过方法:文件上传绕过技巧

  风险评级:高风险

  安全建议

  ① 对上传文件做有效文件类型判断,采用白名单控制的方法,开放只允许上传的文件型式;

  ② 文件类型判断,应对上传文件的后缀、文件头、图片类的预览图等做检测来判断文件类型,同时注意重命名(Md5加密)上传文件的文件名避免攻击者利用WEB服务的缺陷构造畸形文件名实现攻击目的;

  ③ 禁止上传目录有执行权限;

  ④ 使用随机数改写文件名和文件路径,使得用户不能轻易访问自己上传的文件。

  4、命令注入漏洞

  漏洞描述

  目标网站未对用户输入的字符进行特殊字符过滤或合法性校验,允许用户输入特殊语句,导致各种调用系统命令的web应用,会被攻击者通过命令拼接、绕过黑名单等方式,在服务端运行恶意的系统命令。

  渗透测试

  风险评级:高风险

  安全建议

  ① 拒绝使用拼接语句的方式进行参数传递;

  ② 尽量使用白名单的方式(首选方式);

  ③ 过滤危险方法、特殊字符,如:【|】【&】【;】【’】【"】等

  5、SQL注入漏洞

  漏洞描述

  目标网站未对用户输入的字符进行特殊字符过滤或合法性校验,允许用户输入特殊语句查询后台数据库相关信息

  渗透测试

  ① 手动测试:判断是否存在SQL注入,判断是字符型还是数字型,是否需要盲注

  ② 工具测试:使用sqlmap等工具进行辅助测试

  风险评级:高风险

  安全建议

  ① 防范SQL注入攻击的最佳方式就是将查询的逻辑与其数据分隔,如Java的预处理,PHP的PDO

  ② 拒绝使用拼接SQL的方式

  6、跨站脚本漏洞

  漏洞描述

  当应用程序的网页中包含不受信任的、未经恰当验证或转义的数据时,或者使用可以创建 HTML或JavaScript 的浏览器 API 更新现有的网页时,就会出现 XSS 缺陷。XSS 让攻击者能够在受害者的浏览器中执行脚本,并劫持用户会话、破坏网站或将用户重定向到恶意站点。

  三种XSS漏洞:

  ① 存储型:用户输入的信息被持久化,并能够在页面显示的功能,都可能存在存储型XSS,例如用户留言、个人信息修改等。

  ② 反射型:URL参数需要在页面显示的功能都可能存在反射型跨站脚本攻击,例如站内搜索、查询功能。

  ③ DOM型:涉及DOM对象的页面程序,包括:document.URL、document.location、document.referrer、window.location等

  渗透测试

  存储型,反射型,DOM型

  风险评级:高风险

  安全建议

  ① 不信任用户提交的任何内容,对用户输入的内容,在后台都需要进行长度检查,并且对【<】【>】【"】【’】【&】等字符做过滤

  ② 任何内容返回到页面显示之前都必须加以html编码,即将【<】【>】【"】【’】【&】进行转义。

  7、跨站请求伪造漏洞

  漏洞描述

  CSRF,全称为Cross-Site Request Forgery,跨站请求伪造,是一种网络攻击方式,它可以在用户毫不知情的情况下,以用户的名义伪造请求发送给被攻击站点,从而在未授权的情况下进行权限保护内的操作,如修改密码,转账等。

  渗透测试

  风险评级:中风险(如果相关业务极其重要,则为高风险)

  安全建议

  ① 使用一次性令牌:用户登录后产生随机token并赋值给页面中的某个Hidden标签,提交表单时候,同时提交这个Hidden标签并验证,验证后重新产生新的token,并赋值给hidden标签;

  ② 适当场景添加验证码输入:每次的用户提交都需要用户在表单中填写一个图片上的随机字符串;

  ③ 请求头Referer效验,url请求是否前部匹配Http(s)😕/ServerHost

  ④ 关键信息输入确认提交信息的用户身份是否合法,比如修改密码一定要提供原密码输入

  ⑤ 用户自身可以通过在浏览其它站点前登出站点或者在浏览器会话结束后清理浏览器的cookie;

  8、内部后台地址暴露

  漏洞描述

  一些仅被内部访问的地址,对外部暴露了,如:管理员登陆页面;系统监控页面;API接口描述页面等,这些会导致信息泄露,后台登陆等地址还可能被爆破。

  渗透测试

  ① 通过常用的地址进行探测,如login.html,manager.html,api.html等;

  ② 可以借用burpsuite和常规页面地址字典,进行扫描探测

  风险评级:中风险

  安全建议

  ① 禁止外网访问后台地址

  ② 使用非常规路径(如对md5加密)

  9、信息泄露漏洞

  漏洞描述

  ① 备份信息泄露:目标网站未及时删除编辑器或者人员在编辑文件时,产生的临时文件,或者相关备份信息未及时删除导致信息泄露。

  ② 测试页面信息泄露:测试界面未及时删除,导致测试界面暴露,被他人访问。

  ③ 源码信息泄露:目标网站文件访问控制设置不当,WEB服务器开启源码下载功能,允许用户访问网站源码。

  ④ 错误信息泄露:目标网站WEB程序和服务器未屏蔽错误信息回显,页面含有CGI处理错误的代码级别的详细信息,例如SQL语句执行错误原因,PHP的错误行数等。

  ⑤ 接口信息泄露:目标网站接口访问控制不严,导致网站内部敏感信息泄露。

  渗透测试

  ① 备份信息泄露、测试页面信息泄露、源码信息泄露,测试方法:使用字典,爆破相关目录,看是否存在相关敏感文件

  ② 错误信息泄露,测试方法:发送畸形的数据报文、非正常的报文进行探测,看是否对错误参数处理妥当。

  ③ 接口信息泄露漏洞,测试方法:使用爬虫或者扫描器爬取获取接口相关信息,看目标网站对接口权限是否合理

  风险评级:一般为中风险,如果源码大量泄漏或大量客户敏感信息泄露。

  安全建议

  ① 备份信息泄露漏洞:删除相关备份信息,做好权限控制

  ② 测试页面信息泄露漏洞:删除相关测试界面,做好权限控制

  ③ 源码信息泄露漏洞:做好权限控制

  ④ 错误信息泄露漏洞:将错误信息对用户透明化,在CGI处理错误后可以返回友好的提醒语以及返回码。但是不可以提醒用户出错的代码级别的详细原因

  ⑤ 接口信息泄露漏洞:对接口访问权限严格控制

  10、失效的身份认证

  漏洞描述

  通常,通过错误使用应用程序的身份认证和会话管理功能,攻击者能够破译密码、密钥或会话令牌, 或者利用其它开发缺陷来暂时性或永久性冒充其他用户的身份。

  渗透测试

  ① 在登陆前后观察,前端提交信息中,随机变化的数据,总有与当前已登陆用户进行绑定的会话唯一标识,常见如cookie

  ② 一般现在网站没有那种简单可破解的标识,但是如果是跨站认证,单点登录场景中,可能为了开发方便而简化了身份认证

  风险评级:高风险

  安全建议

  ① 使用强身份识别,不使用简单弱加密方式进行身份识别;

  ② 服务器端使用安全的会话管理器,在登录后生成高度复杂的新随机会话ID。会话ID不能在URL中,可以安全地存储,在登出、闲置超时后使其失效。

  11、失效的访问控制

  漏洞描述

  未对通过身份验证的用户实施恰当的访问控制。攻击者可以利用这些缺陷访问未经授权的功能或数据,例如:访问其他用户的帐户、查看敏感文件、修改其他用户的数据、更改访问权限等。

  渗透测试

  ① 登入后,通过burpsuite 抓取相关url 链接,获取到url 链接之后,在另一个浏览器打开相关链接,看能够通过另一个未登入的浏览器直接访问该功能点。

  ② 使用A用户登陆,然后在另一个浏览器使用B用户登陆,使用B访问A独有的功能,看能否访问。

  风险评级:高风险

  安全建议

  ① 除公有资源外,默认情况下拒绝访问非本人所有的私有资源;

  ② 对API和控制器的访问进行速率限制,以最大限度地降低自动化攻击工具的危害;

  ③ 当用户注销后,服务器上的Cookie,JWT等令牌应失效;

  ④ 对每一个业务请求,都进行权限校验。

  12、安全配置错误

  漏洞描述

  应用程序缺少适当的安全加固,或者云服务的权限配置错误。

  ① 应用程序启用或安装了不必要的功能(例如:不必要的端口、服务、网页、帐户或权限)。

  ② 默认帐户的密码仍然可用且没有更改。

  ③ 错误处理机制向用户披露堆栈跟踪或其他大量错误信息。

  ④ 对于更新的系统,禁用或不安全地配置最新的安全功能。

  ⑤ 应用程序服务器、应用程序框架(如:Struts、Spring、ASP.NET)、库文件、数据库等没有进行相关安全配置。

  渗透测试

  先对应用指纹等进行信息搜集,然后针对搜集的信息,看相关应用默认配置是否有更改,是否有加固过;端口开放情况,是否开放了多余的端口;

  风险评级:中风险

  安全建议

  搭建最小化平台,该平台不包含任何不必要的功能、组件、文档和示例。移除或不安装不适用的功能和框架。在所有环境中按照标准的加固步骤进行正确安全配置。

  13、使用含有已知漏洞的组件

  漏洞描述

  使用了不再支持或者过时的组件。这包括:OS、Web服务器、应用程序服务器、数据库管理系统(DBMS)、应用程序、API和所有的组件、运行环境和库。

  渗透测试

  ① 根据前期信息搜集的信息,查看相关组件的版本,看是否使用了不在支持或者过时的组件。一般来说,信息搜集,可通过http返回头、相关错误信息、应用指纹、端口探测(Nmap)等手段搜集。

  ② Nmap等工具也可以用于获取操作系统版本信息

  ③ 通过CVE,CNVD等平台可以获取当前组件版本是否存在漏洞

  风险评级:按照存在漏洞的组件的安全风险值判定当前风险。

  安全建议

  ① 移除不使用的依赖、不需要的功能、组件、文件和文档;

  ② 仅从官方渠道安全的获取组件(尽量保证是最新版本),并使用签名机制来降低组件被篡改或加入恶意漏洞的风险;

  ③ 监控那些不再维护或者不发布安全补丁的库和组件。如果不能打补丁,可以考虑部署虚拟补丁来监控、检测或保护。

  详细学习可参考:

  以上就是百学百科小编解答(繁华乱世沧桑了谁容颜ゝ)解答关于“渗透测试应该怎么做呢?”的答案,接下来继续为你详解用户(甜`诱少女。)分析“混凝土试块的抗渗试验步骤是什么,通俗一点的说法”的一些相关解答,希望能解决你的问题!

  提问二:混凝土试块的抗渗试验步骤是什么,通俗一点的说法

  本文贡献者:【甜`诱少女。】 ,解答(渗透测试七个步骤)的问题,如果问题解决,可以关注本站!

  答在采用氯离子渗透法测试混凝土试块的渗透性时,需要将混凝土试块浸泡在一定浓度的氯离子水池中。

  氯离子从混凝土试块的一侧向另一侧渗透,在试验一段时间后,取出混凝土试块,并将其烘干,并沿着氯离子溶液侧向另一侧的方向切成薄片,并在每片薄片上取样,分析氯离子含量,从而确定了氯离子渗透方向上的浓度梯度,并根据此计算混凝土试块的渗透系数。

  采用该方法可以较为准确的测出混凝土的抗渗性能,但是该测试方法所需要的时间较长,至少需要花费十几天至几个月的时间。而对于渗透能力较弱的混凝土试块,则需要的时间相对更长。

  图如下:(这是一个整体图)

  扩展资料

  混凝土试块的抗渗含水率对抗渗透能力强度的影响

  在进行试件的抗渗透能力强度测试时,试件内部的含水率需要符合规范的基本要求,根据试件相关规范可知,试块内部含水率需要控制在8~12%,若测得试块内部含水率超限时,需要将试块放置在60±5℃环境下进行烘烤至合适的含水率。

  根据相关研究表明,切块抗渗透能力强度随着内部含水率的增大而逐渐的降低,当试块含水率控制在8%时,其抗渗透能力强度较强,当含水率为12%时,试件的抗渗透能力较弱。

  因此,为了确保试块抗渗透能力强度符合要求,需要将含水率控制在(10±1)%范围内。

  参考资料来源:百度百科-抗渗混凝土

  以上就是百学百科小编解答(甜`诱少女。)回答关于“混凝土试块的抗渗试验步骤是什么,通俗一点的说法”的答案,接下来继续为你详解用户(意相左)解答“渗透测试的步骤有哪些”的一些相关解答,希望能解决你的问题!

  提问三:渗透测试的步骤有哪些

  本文最佳回答用户:【意相左】 ,现在由百学百科小编为你分析与【渗透测试七个步骤】的相关内容!

  答渗透测试步骤

  明确目标

  · 确定范围:测试目标的范围,ip,域名,内外网。

  · 确定规则:能渗透到什么程度,时间能否修改上传能否提权等。

  · 确定需求:web应用的漏洞、业务逻辑漏洞、人员权限管理漏洞等等。

  信息收集

  方式:主动扫描,开放搜索等。

  开放搜索:利用搜索引擎获得,后台,未授权页面,敏感url等。

  漏洞探索

  利用上一步中列出的各种系统,应用等使用相应的漏洞。

  方法:

  1.漏扫,awvs,IBM appscan等。

  2.结合漏洞去exploit-db等位置找利用。

  3.在网上寻找验证poc。

  内容:

  系统漏洞:系统没有及时打补丁

  Websever漏洞:Websever配置问题

  Web应用漏洞:Web应用开发问题

  其它端口服务漏洞:各种21/8080(st2)/7001/22/3389

  通信安全:明文传输,token在cookie中传送等。

  漏洞验证

  将上一步中发现的有可能可以成功利用的全部漏洞都验证一遍,结合实际情况,搭建模拟环境进行试验。成功后再应用于目标中。

  自动化验证:结合自动化扫描工具提供的结果

  手工验证,根据公开资源进行验证

  试验验证:自己搭建模拟环境进行验证

  登陆猜解:有时可以尝试猜解一下登陆口的账号密码等信息

  业务漏洞验证:如发现业务漏洞,要进行验证

  公开资源的利用

  信息分析

  为下一步实施渗透做准备:

  精准打击:准备好上一步探测到的漏洞的exp,用来精准打击

  绕过防御机制:是否有防火墙等设备,如何绕过

  定制攻击路径:最佳工具路径,根据薄弱入口,高内网权限位置,最终目标

  绕过检测机制:是否有检测机制,流量监控,杀毒软件,恶意代码检测等

  攻击代码:经过试验得来的代码,包括不限于xss代码,sql注入语句等

  获取所需

  实施攻击:根据前几步的结果,进行攻击

  获取内部信息:基础设施

  进一步渗透:内网入侵,敏感目标

  持续性存在:一般我们对客户做渗透不需要。rookit,后门,添加管理账号,驻扎手法等

  清理痕迹:清理相关日志,上传文件等

  信息整理

  整理渗透工具:整理渗透过程中用到的代码,poc,exp等

  整理收集信息:整理渗透过程中收集到的一切信息

  整理漏洞信息:整理渗透过程中遇到的各种漏洞,各种脆弱位置信息

  形成报告

  按需整理:按照之前第一步跟客户确定好的范围,需求来整理资料,并将资料形成报告

  补充介绍:要对漏洞成因,验证过程和带来危害进行分析

  修补建议:当然要对所有产生的问题提出合理高效安全的解决办法

  最后,你如何评价[渗透测试七个步骤]?欢迎下面互动!想了解更多精彩内容,快来关注本站吧。

版权声明:本文内容转载自网络,该文观点仅代表作者本人。登载此文出于传递更多信息之目的,并不意味着赞同其观点或证实其描述。文章内容仅供参考,不构成投资建议。如发现本站有涉嫌抄袭侵权/违法违规的内容,请联系本站举报,一经查实,本站将立刻删除。