博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
对php代码混淆的研究
阅读量:6291 次
发布时间:2019-06-22

本文共 1040 字,大约阅读时间需要 3 分钟。

  hot3.png

混淆方法:

两个文件采用了4种混淆方法对代码进行混淆
1、局部变量追加乱码
对于局部变量,在经过转为无意义单字符后,在变量名后追加多个'\xEF\xBD\xBD'字符,并在其中混杂一些其他不可见字符(7E以后的),给人以乱码的感觉,单实际上并无影响。局部变量可以任意命名,只要能区分出来就行。
2、利用unicode加转义符显示字符串,采用十进制和十六进制两种方式进行显示,避免直观看到。
php可以使用如"\150\157\155\145\120\141\164\150"(十进制)或"\x73\x79\x73\x74\x65\x6d\x4c\x6f\x67"(十六进制)在文件中作为变量名。这种方式直接
3、利用php字符串可以用作函数名,将常用函数名隐藏
    使用了
$GLOBALS全局变量
define宏函数
base64_decode函数
以及自定义不可逆函数_kstr2()函数
4、使用字符串连接符号来连接被分割并转换的字符串

其中_kstr2()代码还原后的结果如下

function _kstr2($str) {        $len = strlen($str);        $result = '';        $baseChar = ord($str[0]) - 30;        for ($str = 1; $str < $len; $str+= 2) {            if ($str + 1 < $len) {                $result.= chr(ord($str[$str + 1]) + $baseChar );                $result.= chr(ord($str[$str]) + $baseChar );            } else {                $result.= chr(ord($str[$str]) + $baseChar );            }        }        return $result;    }}

由这段代码可以看出,被加密的字符串的第一个字符是一个随机字符,因此,即使是同一个字符串,在加密后得到的结果也可能是不一样的,这样大大提高了混淆的混乱程度。但,这个函数放在被混淆的代码之中,为代码还原提供了便利。

转载于:https://my.oschina.net/rodger/blog/2249820

你可能感兴趣的文章
vs2012建一个空解决方案添加以前老版本的Web项目调试弹出window安全
查看>>
C# 实现抓取网页内容(一)
查看>>
golang中并发sync和channel
查看>>
margin重叠与line-height属性
查看>>
服务器跟PC机的区别(转)
查看>>
Java核心技术之基础知识
查看>>
读书笔记_写给自学者的入门指南 >博客园||知识库
查看>>
iOS应用之间的跳转与数据传递
查看>>
CCleaner使用说明
查看>>
NOIP专题复习3 图论-强连通分量
查看>>
hdu Dragon Balls
查看>>
java代码-----indexOf()方法--从字符串的某个字符的第一次出现的位子开始
查看>>
java代码=====实现修改while()
查看>>
python (11)文件的读写 按行读文件
查看>>
Python 结巴分词(2)关键字提取
查看>>
python异常处理,日志处理
查看>>
MySQL字符集问题
查看>>
node服务器端模块化-commomjs
查看>>
20165330 2017-2018-2 《Java程序设计》第7周学习总结
查看>>
[转] css选择器中:first-child与:first-of-type的区别
查看>>