写在前面:

  1. 渗透测试包含但不限于Web安全
  2. 渗透测试并不相当于Web渗透
  3. Web安全学习是入门渗透测试最容易的途径,门槛最低

Web安全入门:

  1. 基础入门
  2. 整体框架
  3. SQL注入
  4. XSS攻击
  5. 业务逻辑漏洞
  6. 代码审计
  7. 安全编程

如何学习(学习的路线):

  1. web 的基础知识(重要)
  2. 漏洞原理
    SQL、XSS、文件上传、CSRF、SSRF、XXE等
  3. 编程能力(重要)
  4. 实战练习
    实战练习是从头贯穿到尾的

下面从几个方面具体说明

一、基础知识(杂/乱)

需要的基础知识包括但不限于以下几点:

  1. 编程基础                      主要指脚本语言,比如PHP、Python
  2. 网络常识                      计算机网络(大学教材), 计算机网络自顶向下的方法(外国著作)
  3. 服务器的基本使用        Linux/Windows(Linux 是重点)  ,基本命令(鸟哥的 Linux 私房菜), 部署Web服务器
  4. 基础软件的使用           VMware、数据库
  5. 计算机基础(软/硬件)软件部分主要指操作系统,进程、线程等,硬件部分主要包括内存、CPU、网卡

以上五点之中,前三点很重要!

二、编程语言

  1. PHP/JSP/ASPX
  2. Python
  3. HTML
  4. JavaScript

前期推荐学 PHP、Python。HTML 和 CSS 了解、能够看懂并写简单的 HTML 代码。JavaScript 要重点掌握。

实际应用:

  1. 代码审计
  2. 安全开发
  3. 安全运维

三、网络基础

  1. OSI 七层参考模型
  2. TCP/IP 模型

把握以下重点:

  1. TCP 协议
  2. IP 协议
  3. HTTP 协议
  4. DNS 协议

学会使用工具:

  1. wireshark      主要分析基于 TCP/IP 协议底层的数据包
  2. burpsuit         主要分析 HTTP 协议的数据包
  3. nmap             端口扫描
  4. OWASP         目录爆破

一定一定要知道原理,不然这是一个脚本小子,知识面的大小决定攻击面的大小,原理很重要!

三、服务器的基本使用

  1. Linux/Windows
  2. 基础命令
  3. 环境搭建

推荐书籍: 鸟哥的 Linux 私房菜,篇幅较长可以当工具书来查阅,但是最好多翻一翻。

四、整体框架

常见的 Web 漏洞:

  1. SQL 注入
  2. 文件上传
  3. 文件包含
  4. 命令执行
  5. XSS
  6. CSRF
  7. SSRF
  8. XXE
  9. 中间件安全
  10. 业务逻辑漏洞
  11. 常见框架漏洞

以下为几个重点的:

1. SQL 注入(建议首先要掌握的漏洞)

掌握:

数据库的增删改查

了解:
关系型数据库 MySQL/MSSQL/Oracle
非关系型数据库 Redis/Memchche/MongoDb

工具:
SQLmap/NoSQLmap
SQLmap 支持12种关系型数据库的注入
NoSQLmap 支持非关系型数据库的注入

学完基础的之后:

  1. 联合注入
  2. 时间盲注
  3. 布尔盲注
  4. 报错盲注
  5. 命令执行

针对不同数据库的攻击技巧是不同的,不能用工具一把梭。细节就是和大佬之间的区别!

推荐书籍: SQL注入攻击与防御(第二版)     sqlmap从入门到精通(简单看一下就行)

2. XSS(跨站脚本攻击)

  1. 反射型
  2. 存储型(重点)
  3. DOM型

作用:

  1. cookie 窃取
  2. 键盘记录
  3. 网页截屏
  4. 网页挂马
  5. XSS 蠕虫
  6. 钓鱼攻击
  7. 水坑攻击
  8. 经纬度定位

入门书籍: XSS 跨站脚本攻击剖析与防御(有几年了,略老)

3. 业务逻辑漏洞(代码逻辑的问题)

  1. 身份认证安全
  2. 数据篡改
  3. 未授权访问
  4. 任意密码找回
  5. 验证码突破
  6. 接口调用安全
  7. 其他逻辑漏洞

4. 代码审计

检查源代码的安全缺陷,源代码是否存在安全隐患或者编写不规范的地方。

如何进行代码审计(方法论):

  1. 审计环境的准备
  2. 学习审计代码的流程
  3. 牢记常见的危险函数以及特殊函数
  4. 细心 + 耐心 + 一点小运气

入门书籍:《代码审计:企业级 Web 代码安全架构》

总结

Web 安全的本质

  1. 用户能控制输入的内容
  2. 服务端没有对用户输入的内容进行检查过滤
  3. Web 应用把用户输入的内容带入到某个地方执行

渗透测试职业的后半部分应该是安全体系建设的能力,这才是价值的体现,要从实践中获取经验,从经验中抽象出事物的本质。

渗透测试之Web安全的更多相关文章

  1. 小白日记51:kali渗透测试之Web渗透-WebShell(中国菜刀、WeBaCoo、Weevely)

    webshell 本质:<?php echo shell_exec($_GET['cmd']);?> windows平台 中国菜刀官网:胖客户端程序,国产中比较优秀的webshell,适用 ...

  2. 小白日记30:kali渗透测试之Web渗透-扫描工具-Skipfish

    WEB渗透-skipfish Skipfish是一个命令行模式,以C语言编写的积极的Web应用程序的安全性侦察工具,没有代理模式. 它准备了一个互动为目标的网站的站点地图进行一个递归爬网和基于字典的探 ...

  3. 小白日记28:kali渗透测试之Web渗透-扫描工具-Nikto

    扫描工具-Nikto #WEB渗透 靶机:metasploitable 靶场:DVWA[默认账号/密码:admin/password] #新手先将DVWA的安全性,调到最低,可容易发现漏洞 侦察[减少 ...

  4. 小白日记54:kali渗透测试之Web渗透-补充概念(AJAX,WEB Service)

    补充概念 AJAX(异步javascript和XML) Asynchronous javascript and xml 是一个概念,而非一种新的编程语言,是一组现有技术的组合 通过客户端脚本动态更新页 ...

  5. 小白日记52:kali渗透测试之Web渗透-HTTPS攻击(Openssl、sslscan、sslyze、检查SSL的网站)

    HTTPS攻击 全站HTTPS正策划稿那位潮流趋势 如:百度.阿里 HTTPS的作用 CIA 解决的是信息传输过程中数据被篡改.窃取 [从中注入恶意代码,多为链路劫持] 加密:对称.非对称.单向 HT ...

  6. 小白日记50:kali渗透测试之Web渗透-CSRF

    CSRF CSRF原理:经常与XSS混淆. 从信任的角度进行区分:XSS:利用用户对站点的信任:CSRF:利用站点对已经身份认证的信任(有一定的信任)[默认情况:站点不信任客户端] 结合社工在身份认证 ...

  7. 小白日记49:kali渗透测试之Web渗透-XSS(三)-存储型XSS、DOM型XSS、神器BEFF

    存储型XSS与DOM型XSS [XSS原理] 存储型XSS 1.可长期存储于服务器端 2.每次用户访问都会被执行js脚本,攻击者只需侦听指定端口 #攻击利用方法大体等于反射型xss利用 ##多出现在留 ...

  8. 小白日记47:kali渗透测试之Web渗透-XSS(一)

    XSS [推荐书籍:XSS跨站脚本攻击剖析与防御] xss表示Cross Site Scripting(跨站脚本攻击),它与SQL注入攻击类似,SQL注入攻击中以SQL语句作为用户输入,从而达到查询/ ...

  9. 小白日记46:kali渗透测试之Web渗透-SqlMap自动注入(四)-sqlmap参数详解- Enumeration,Brute force,UDF injection,File system,OS,Windows Registry,General,Miscellaneous

    sqlmap自动注入 Enumeration[数据枚举] --privileges -U username[CU 当前账号] -D dvwa -T users -C user --columns  [ ...

随机推荐

  1. CentOS7 安装python 3.5 及 pip安装

    1.CentOS7 安装Python 的依赖包 # yum install -y zlib-devel bzip2-devel openssl-devel ncurses-devel sqlite-d ...

  2. echart 之实现温度计

    百度这个图表支持不是很好,有的需要自己写,看大神们实现温度计都是用 水球特效实现的我这里雕虫小计啊但是满足我了我的项目需求特此分享出来,可惜自己不是专业的前端 这是我的实现结果 好了上代码html: ...

  3. 关于有趣的windows.h

    system 函数: 这个函数差不多就是调用 cmd (命令提示符). 当然,不一定要在程序中调用,用 txt 打入文本( 不用加system() )后改后缀名为 cmd 后运行即可. Win 键 + ...

  4. AOP和spring AOP学习记录

    AOP基本概念的理解 面向切面AOP主要是在编译期或运行时,对程序进行织入,实现代理, 对原代码毫无侵入性,不破坏主要业务逻辑,减少程序的耦合度. 主要应用范围: 日志记录,性能统计,安全控制,事务处 ...

  5. mongodb忘记密码处理步骤

    mongodb忘记密码的处理办法较MySQL等数据库而言方法显得更加暴力,处理方式如下: 1.  修改mongodb的配置文件 mongodb的配置文件一般可以通过查看进程的方式查看文件名,例如: p ...

  6. 基于springcloud框架搭建项目-Eureka篇(一)

    springcloud项目近年来算是很流行的了,不少公司项目目前都用到了,毕竟优点很多,刚好公司项目用到了,根据自己的理解,简单搭建一下,以便以后学习 这里简单的介绍一下它: SpringCloud, ...

  7. 2020centos解决“nginx 403 Forbidden"错误的故事

    最近折腾一个放在日本的vps,网速还可以,就是经常丢包. 原本配置了Nginx的做代理服务器,我想反正服务器空闲者,放点我自己的资料 配置了一个静态html文件,方便自己随时查看 结果,不停的修改ng ...

  8. Effective Go中文版(更新中)

    原文链接:https://golang.org/doc/effective_go.html Introduction Go是一种新兴的编程语言.虽然它借鉴了现有语言的思想,但它具有不同寻常的特性,使得 ...

  9. Hadoop集群搭建(一)~虚拟机的创建

    Hadoop集群的搭建包括,虚拟机系统的安装:安装JDK,Hadoop:克隆虚拟机:伪分布式的搭建:安装zookeeper:Hive:Hbae:Spark等等: 我将分为多篇文章来记录.这篇文章主要写 ...

  10. H5页面,输入框的光标,如果页面上下滑动光标停留在页面上,除了输入框外,松手过了一段时间才跑回输入框里面

    有点类似这种情况 其中一个博主描述得比较详细,主要还有图 我是直接在App.vue主文件那里添加一下代码,主要是添加一个监听器,如果touchmove的时候就会触发让其失焦,就会消失那个光标,需要再次 ...