首页
学习
活动
专区
圈层
工具
发布

php 不用字母,数字和下划线写 shell

CTF 遇到一道正则过滤了字母,数字和下划线的题目,发现了一些 PHP 的骚姿势,感觉很有必要总结一下。...例如非数字字母的 PHP 后门 php $_++; print($_); ?> 结果会输出:1 不用数字和字母的 shell 在讲不用数字,字母和下划线写 shell 之前,先了解下不用数字和字母写 shell。...然后再利用 PHP 允许动态函数执行的特点,拼接处一个函数名,如 "assert",然后动态执行即可。 非字母、数字的字符异或出字母 不可打印字符,用 url 编码表示。 非字母、数字的字符取反出字母 利用的是 UTF-8 编码的某个汉字,将其中的某个字符取出来,取反为字母。一个汉字的 utf8 是三个字节,{2} 表示第 3 个字节 <?

3K10

无字母数字webshell

最近ctf经常遇到类似姿势的题目,最开始还是比较蒙的 今天来进行一个总结 文章参考p牛的博客 一些不包含数字和字母的webshell 无字母数字 如何构造一句话木马。...这里用到三种方法 异或构造 这种方法用到特殊符号的异或最终得到数字或者字母 如上图 echo "~"^"$" echo "^"^"<" 即可构造出字母 转换过程为 将两个要比较的字符转换成ascii之后...转换成ascii为90 也就是对应大写字母Z 那么我们如果构造处一句话 不可能一个一个去试对吧 这里贴上一个 异或得到字母的PHP脚本 php $test = '~!@#$%^&*()_+\|/?....] p )^@ i .^@ n =^{ f @^/ o 传入的知识phpinfo字符串 最终还需传入括号 最终payload为 http://127.0.0.1/webshell/ctf.php

1.4K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    cpu电压解释;cpu上面的数字和字母

    cpu上面的数字和字母 intel处理器后缀名“F”含义: 在intel CPU型号后缀字母中,“F”是intel全新推出的后缀,代表无内置核心显卡版本,也就是说,我们如果选择“F”后缀名的处理器型号,...字母G:Intel和AMD合作的产品,Intel提供CPU核心,AMD提供GPU核心,通常叫Kaby Lake G处理器。 字母H:移动版CPU,支持超线程,比如i5-8400H。...字母M:酷睿五代后就没有了,表示标压双核移动版CPU,笔记本常见,比如i5-4310M。 字母R:移动版处理器,和C后缀一样,封装不同,比如i7-5775R。...字母T:低功耗版台式CPU,频率和睿频都降低,比如i7-8700T。 字母U:低电压版的笔记本CPU,轻薄本常见,比如i7-8550U。...2、锐龙和因特尔一样是有3/5/7的级别划分。 3、第一个数字也是很老套的代表几代处理器,比如5700X就是五代,7700X就是七代。代数后的三个数字也还是SKU型号,数字大的性能好。

    57610

    大小写字母、数字的ASCII码值,及字母数字的转换

    SCII(American Standard Code for Information Interchange,美国标准信息交换代码)是基于拉丁字母的一套电脑编码系统,主要用于显示现代英语和其他西欧语言...大写字母/小写字母及数字的ASCII码(数字)值对照: a-z:97-122 A-Z:65-90 0-9:48-57 大小写字母和数字的ASCII转换: 数字转字母: 语法: String.fromCharCode...(num1, ..., numN) 参数: num1, ..., numN 一系列 UTF-16 代码单元的数字。...1被截断并被忽略 字符/字母转数字: 单字符转数字: 'a'.charCodeAt(0) 结果: 97  封装的方法: function convert(num){     return num 数字的ASCII码值,及字母数字的转换》 https://www.w3h5.com/post/414.html

    7.5K10

    无字母数字Webshell之提高篇

    这题可能来自是我曾写过的一篇文章:《一些不包含数字和字母的Webshell》,里面介绍了如何构造无字母数字的webshell。...其中有两个主要的思路: 1.利用位运算 2.利用自增运算符 当然,这道题多了两个限制: 1.webshell长度不超过35位 2.除了不包含字母数字,还不能包含$和_ 难点呼之欲出了,我前面文章中给出的所有方法...PHP自然也能够和操作系统进行交互,“反引号”就是PHP中最简单的执行shell的方法。那么,在使用PHP无法解决问题的情况下,为何不考虑用“反引号”+“shell”的方式来getshell呢?...PHP5+shell打破禁锢 因为反引号不属于“字母”、“数字”,所以我们可以执行系统命令,但问题来了:如何利用无字母、数字、$的系统命令来getshell?...好像问题又回到了原点:无字母、数字、$,在shell中仍然是一个难题。

    1.6K41

    Web安全 | 无字母数字Webshell 总结

    所以我们的思路是,将非字母数字的字符经过各种转换,最后能构造出 a-z0-9 中的任意一个字符。...如果正则匹配过滤了字母和数字,那就可以使用两个不在正则匹配范围内的非字母非数字的字符进行异或,从而得到我们想要的字符串。 例如,我们异或 ?...那么或运算原理也是一样,如果正则匹配过滤了字母和数字,那就可以使用两个不在正则匹配范围内的非字母非数字的字符进行或运算,从而得到我们想要的字符串。 构造脚本 下面给出一个或运算绕过的脚本: 字母的话我们完全可以使用 /???/php?????? 来提高匹配几率,但是题目限制的就是字母数字,所以我们的想别的办法。...; } eval($code);} 需要构造无字母数字的 Webshell,但是过滤了 _ 和 $ 就比较麻烦了,并且由于题目时 PHP 5 的环境: image-20210509111617262

    5.9K10

    无字母数字webshell之提高篇

    这题可能来自是我曾写过的一篇文章:《一些不包含数字和字母的webshell》,里面介绍了如何构造无字母数字的webshell。...其中有两个主要的思路: 利用位运算 利用自增运算符 当然,这道题多了两个限制: webshell长度不超过35位 除了不包含字母数字,还不能包含$和_ 难点呼之欲出了,我前面文章中给出的所有方法,都用到了...PHP自然也能够和操作系统进行交互,“反引号”就是PHP中最简单的执行shell的方法。那么,在使用PHP无法解决问题的情况下,为何不考虑用“反引号”+“shell”的方式来getshell呢?...PHP5+shell打破禁锢 因为反引号不属于“字母”、“数字”,所以我们可以执行系统命令,但问题来了:如何利用无字母、数字、$的系统命令来getshell?...好像问题又回到了原点:无字母、数字、$,在shell中仍然是一个难题。

    1.5K60

    javascript 自己实现数字字母和中文的混合排序方法 by FungLeo

    javascript 自己实现数字\字母和中文的混合排序方法(纯粹研究,不实用) 前言 在上一篇博文《javascript 数组排序sort方法和自我实现排序方法的学习小结》中,我用自己的方法实现了数字数组的排序...当然,实际运用中,我还是会使用sort方法更加方便.但是,我上一篇博文,仅仅是实现了数字排序,而srot方法默认可是能给字母实现排序的哦!而我的代码只能排序数字,看起来还是弱弱的....所以,我得加上能排字母甚至中文的排序方法....Unicode 是 0 - 65535 之间的整数 其他说明 按照正常的排序逻辑,应该是:数字比一切字母都小,字母比一切中文都小,中文应该按照首字拼音的首字母排序....逻辑也应该可以实现,把数字字母中文分别找出来,数字跟数组进行比较,字母跟字母比较,中文跟中文比较,然后拼接数组 中文获取首字的首字母可能稍微麻烦一点. 汉字居然可以直接比对的.

    1.8K20
    领券