OSCP考试回顾
技术背景
从2011年开始接触学习渗透测试,全职做过的职位有渗透测试,Python后端研发,DevOps,甲方安全打杂.
学习过程
首先考试报名,交钱。买了价值800美元的一个月lab,包含Pentest with Kali的视频教程和一个PDF还有一次考试费用。视频教程和PDF介绍了一些常见工具,没有其他。
3月报名,买了一个月Lab,Lab环境需要预约,最早能预约到报名时间2周后的。
关于OSCP Lab环境:
大概有55台机器?,我做了50台的样子,最后比较难的HUMBLE没做出来。Lab环境偏向Exploit利用和Post-exploition,机器提权,端口转发,windows域都有。Web题目有涉及,但是很浅显,最有意思也是最难的部分应该是提权。
关于BOF:
Buffer over flow也是OSCP一个核心知识点,花了一周多才基本搞定,建议买Lab前先学习,以免浪费Lab时间。
断断续续刷着HackTheBox,一共做了40个机器,这是考试前的HTB成绩截图:

HTB+OSCP Lab+Vulnhub一共做了将近100台机器。
考试资料
HackTheBox https://hackthebox.eu
Vulnhub http://vulnhub.com/
OSCP Lab环境相当昂贵,尽量先把HackTheBox Retired Machine都做完,毕竟HTB 的VIP费用才10欧元每月。HTB相对于OSCP Lab来说,HTB的漏洞比较新,OSCP比较旧。
关于Pentest Report
官方提供了一个Report模板,这个模板是围绕漏洞复现和如何修复漏洞,并没有展示从信息收集到提权的过程。我觉得用起来比较别扭,反正怒改了一下,甚至将如何修复漏洞部分都删除了, 最后提交的报告一共30页。 感觉对于Report还是比较Flexible的,关键是准确清晰地写下拿到权限过程,不必拘泥于官方模板。
我的report目录是这样的:
- Service Enumeration (nmap扫描结果摘要)
- Pentest (渗透测试步骤,一步一步如何拿到shell,尽可能多的截图)
- Privilege Escation (提权步骤)
- Official Screen Shot (官方要求的截图)
关于考试
考试提前20天能预约到下午开始的,大概看了下可以预约早上5点下午3点晚上6点等,好像下午的比较难预约。
考试一共5道题目,1道BOF,4道渗透。渗透最简单那题不需要提权,其他都需要提权。
考试工具对MSF有部分限制,可以无限制使用msfvenom和exploit/multi/handler中的非meterpreter payload。
提交Pentest Report后3个工作日内会收到是否通过的邮件,只告知是否通过没有具体成绩:

证书在考试成绩出来后30左右收到。
感谢这一段旅程帮助我的人
- yh
- Snak2y
- Touhid
- Indra
- darkshadow
- Teckk2
- 3mrgnc3
- Ph3on1x
- Snowty
- ....
Try harder
愿你也经历过那么多尝试无果,令人无望的夜晚。

相关文章推荐
http://nandtech.co/2017/11/07/offensive-security-pwk-experience/
https://www.keiththome.com/oscp-course-review/
OSCP考试回顾的更多相关文章
- VulnHub-[DC-8-9]-系列通关手册
DC8-通关手册 DC-8是另一个专门构建的易受攻击的实验室,目的是在渗透测试领域积累经验. 这个挑战有点复杂,既是实际挑战,又是关于在Linux上安装和配置的两因素身份验证是否可以阻止Linux服务 ...
- 回顾PMP考试
2014年9月20日,于我来说绝对可以说是一个重要的日子.经过考场里4个多小时(4个小时正式的时间+前面的签到以及后面的survey等)的鏖战,出去之后才发现北京外国语大学的楼宇是如此的漂亮,阳光也是 ...
- MySQL和PHP基础考试错题回顾
13.关于exit( )与die( )的说法正确的是( B) C A.当exit( )函数执行会停止执行下面的脚本,而die()无法做到 B.当die()函数执行会停止执行下面的脚本,而exit( ) ...
- PMP考试的过与只是
我在一年多时间里參加了三次PMP考试,前两次都失败,直到第三次才成功.怎样对待失败?这是每个人都会遇到的挑战.假设我们能用正确的态度对待临时的失败,那么终于的成功也就不远了.我希望通过本文与大家分享一 ...
- MSSQL 简单练习回顾
这段时间,报了浦软培训的.NET,现在整理回顾下,算是个小小总结吧 为了便于操作,我没有在多个数据库间切换数据库实例,以一个总的数据库实例 test_demo为源进行的相关操作,代码的注释根据我的理解 ...
- [经验分享] OSCP 渗透测试认证
http://f4l13n5n0w.github.io/blog/2015/05/05/jing-yan-fen-xiang-oscp-shen-tou-ce-shi-ren-zheng/ “120天 ...
- 2017OKR年终回顾与2018OKR初步规划
一.2017OKR - 年终回顾 自从6月份进行了年中总结,又是半年过去了,我的2017OKR又有了一些milestone.因此,按照国际惯例,又到了年终回顾的时候了,拉出来看看完成了多少.(以下目标 ...
- 我的2017OKR - 年中回顾
自从订阅了吴军老师的<硅谷来信>之后,对其中一篇介绍Google的目标管理方法OKR的文章记忆犹新.想到自己喜欢在每年年初的时候给自己定制一些规划,于是乎了解了一下OKR并重构了一下我的2 ...
- [转]一个普通IT人的十年回顾---金旭亮
金旭亮老师十年体会,很有收获.转自网络. 金旭亮于1989年与超级解霸的开发者梁肇新同时迈入广西大学的校门,却走了一条与其不同的路. 1994年起开始自学计算机专业本科课程,并开始编程,从未间断,迄今 ...
随机推荐
- Beats Solo3 Wireless 无法链接 MacBook pro
Beats Solo3 Wireless 无法链接 MacBook pro 问题解决了,原来只要长按耳机的开关按钮就能被识别到了,貌似需要5秒钟不松手. https://bbs.feng.com/re ...
- Java知识点整理(三)
如何设计出高可用的分布式架构 分布式架构 CDN简介 分布式缓存和本地缓存区别 高并发场景常用技术解决方案 JVM优化示例 Docker和JVM区别 Java开发人员需要注意的五大Docker误区 D ...
- BPSK相干解调和DBPSK非相干解调误码率仿真
BPSK相干解调和DBPSK非相干解调误码率仿真 本脚本完成了BPSK和DBPSK两种不同调制方式下的误码率(DBPSK差分相干)仿真, 并和理论曲线进行了对比. 撰写人:*** 最后修改日期:201 ...
- 第109天:Ajax请求GET和POST的区别
一.Ajax请求GET和POST的区别 1.使用Get请求时,参数在URL中显示,而使用Post方式,则不会显示出来 2.使用Get请求发送数据量小,Post请求发送数据量大 3.get请求需注意缓存 ...
- SQL入门之查询入门
select语法一般结构: SELECT [ALL|DISTINCT] <目标列表达式> [别名] [, <目标列表达式> [别名]]... FROM <表名或视图名&g ...
- 【Python】极简单的方式序列化sqlalchemy结果集为JSON
继承 json.JSONEncoder 实现一个针对sqlalchemy返回类型的处理方式. sqlalchemy的返回类型有大都有两种,一种是Model对象,一种是Query集合(只查询部分字段). ...
- HDU4472_Count
题目的意思简单,给你n个点,每个点(除根节点)都有且只有一个父节点.现在问你这些节点关系组成的图有多少种情况满足同一层节点上每个点的后继节点数量相等. 很简单,对于n节点,直接枚举n-1的的所有约数情 ...
- dom对象转成jquery对象时候 变成数组 jquery转成dom时候 取数组第一个
- BZOJ3875 AHOI2014/JSOI2014骑士游戏(动态规划)
容易想到设f[i]为杀死i号怪物所消耗的最小体力值,由后继节点更新.然而这显然是有后效性的,正常的dp没法做. 虽然spfa已经死了,但确实还是挺有意思的.只需要用spfa来更新dp值就可以了.dij ...
- TCP的拥塞控制 (四)
TCP NewReno NewReno是在Reno的基础上,改进了Fast Recovery,主要思想是保证处于network中的packet的总量是饱和的. 在Reno算法中,一个超时会导致相 ...