如何实现代码加密

1、代码为什么要加密?

只要有程序员在,在源代码可读的情况下,无论多么复杂的系统,总有人可以破解其中的奥妙。

就比如Windows Server 2008的激活(没有源代码的情况),最新版的Windows Server 2008需要联机才能激活,即使这样,也有人可以做出注册机。没有源代码的Windows尚且如此,那有源代码就更容易破解了。 
 

人都是有好奇心的 正如那句歌词 :得不到的更加爱、太容易来的就不理睬   所以为了抄袭,为了原创,代码要加密。

下面是一个简单的代码加密,利用base64加密实现代码加密。

function encode_file_contents($filename) {
    $type=strtolower(substr(strrchr($filename,'.'),1));
    if ("php" == $type && is_file($filename) ) { // 如果是PHP文件 并且可写 则进行压缩编码
        $contents = file_get_contents($filename); // 判断文件是否已经被编码处理
        $contents = php_strip_whitespace($filename);

        // 去除PHP头部和尾部标识
        $headerPos = strpos($contents,'<?php');
        $footerPos = strrpos($contents,'?>');
        $contents = substr($contents, $headerPos + 5, $footerPos - $headerPos);
        $encode = base64_encode(gzdeflate($contents)); // 开始编码
        $encode = '<?php'."\n eval(gzinflate(base64_decode("."'".$encode."'".")));\n\n?>";

        return file_put_contents($filename, $encode);
    }
    return false;
}
public function demo()
{
    $filename = '../app/api/controller/Test.php';    //需要加密的文件完整路径
    $aa = $this->encode_file_contents($filename);
    k($aa);die;
    echo "OK,加密完成!";
}

目前也有好多代码加密的软件,大家也可以尝试尝试

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值