php混淆加密解密实战
温馨提示:
本文最后更新于 2020年03月28日,已超过 1,656 天没有更新。若文章内的图片失效(无法正常加载),请留言反馈或直接联系我。
在查看别人的php源码的时候,我们经常会看到加密后的php代码.那么php加密原理是什么呢?怎么解密呢?
混淆加密
我们从百度随便搜索一个加密网站,例如:http://dezend.qiling.org/encrypt/
加密代码:
<?php
/**
* Created by PhpStorm.
* User: tioncico
* Date: 20-3-28
* Time: 上午9:59
*/
class Tioncico{
function testEcho(){
echo "仙士可\n";
}
}
$tioncico = new Tioncico();
$tioncico->testEcho();
加密成功后:
成功执行:
那么,这串代码的加密原理是什么呢?能解密吗?
在这串代码中,我们发现了最后有段代码为:eval();(如果你通过打印eval的第一个变量,可以发现这个变量为base64_decode)
很明显,该代码最后通过这串代码执行,通过echo把eval需要执行的代码输出:
可以发现,它又是一个eval包裹,继续输出:
同理,找到最后的eval,输出:
继续:
则得到了加密前的代码.
混淆加密的原理
混淆加密通过不断重复的base64,然后混淆base64_encode,decode函数,最后通过eval 解密执行完成. 只要稍微了解了一点原理,就能解密成功了.
正文到此结束
- 本文标签: 编程语言
- 本文链接: https://www.php20.cn/article/235
- 版权声明: 本文由仙士可原创发布,转载请遵循《署名-非商业性使用-相同方式共享 4.0 国际 (CC BY-NC-SA 4.0)》许可协议授权