博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
DZX1.5加解密函数authcode分享
阅读量:6428 次
发布时间:2019-06-23

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

  hot3.png

函数所在: /source/function/function_core.php

authcode 是使用异或运算进行加密和解密。

原理如下,假如:

加密

明文:1010 1001

密匙:1110 0011
密文:0100 1010

得出密文0100 1010,解密之需和密匙异或下就可以了

解密

密文:0100 1010

密匙:1110 0011
明文:1010 1001

并没有什么高深的算法,密匙重要性很高,所以,关键在于怎么生成密匙。

function authcode($string, $operation = 'DECODE', $key = '', $expiry = ) {

         $ckey_length = 4;

    $key = md5($key != '' ? $key : getglobal('authkey'));

    $keya = md5(substr($key, , 16));

    $keyb = md5(substr($key, 16, 16));

    $keyc = $ckey_length ? ($operation == 'DECODE' ? substr($string, , $ckey_length): substr(md5(microtime()), -$ckey_length)) : '';

 

    $cryptkey = $keya.md5($keya.$keyc);

    $key_length = strlen($cryptkey);

 

    $string = $operation == 'DECODE' ? base64_decode(substr($string, $ckey_length)) : sprintf('%010d', $expiry ? $expiry + time() : ).substr(md5($string.$keyb), , 16).$string;

    $string_length = strlen($string);

 

    $result = '';

    $box = range(, 255);

 

    $rndkey = array();

    for($i = ; $i <= 255; $i++) {

       $rndkey[$i] = ord($cryptkey[$i % $key_length]);

    }

 

    for($j = $i = ; $i < 256; $i++) {

       $j = ($j + $box[$i] + $rndkey[$i]) % 256;

       $tmp = $box[$i];

       $box[$i] = $box[$j];

       $box[$j] = $tmp;

    }

 

    for($a = $j = $i = ; $i < $string_length; $i++) {

       $a = ($a + 1) % 256;

       $j = ($j + $box[$a]) % 256;

       $tmp = $box[$a];

       $box[$a] = $box[$j];

       $box[$j] = $tmp;

       $result .= chr(ord($string[$i]) ^ ($box[($box[$a] + $box[$j]) % 256]));

    }

 

    if($operation == 'DECODE') {

       if((substr($result, , 10) == 0 || substr($result, , 10) - time() > ) && substr($result, 10, 16) == substr(md5(substr($result, 26).$keyb), , 16)) {

           return substr($result, 26);

       } else {

           return '';

       }

    } else {

       return $keyc.str_replace('=', '', base64_encode($result));

    }

 

}

转载于:https://my.oschina.net/stream/blog/29113

你可能感兴趣的文章
移动计算领域五大机遇:交通运输优势待挖掘
查看>>
如何把win7 旗舰版升级到sp1最新版本
查看>>
Software Enginering-------using git
查看>>
浅谈IP地址-1
查看>>
我的友情链接
查看>>
C#中的线程池使用(一)
查看>>
利用Windows Server Backup功能备份活动目录
查看>>
RAC维护手记08-ASM磁盘组信息查看常用命令
查看>>
实验08 磁盘和文件系统管理
查看>>
我的友情链接
查看>>
我的友情链接
查看>>
FastDFS整合nginx后,nginx一直报错
查看>>
使用Fuel安装OpenStack juno之三使用OpenStack创建云主机和Volume
查看>>
zabbix安装源
查看>>
Eclipse+kafka集群 实例源码
查看>>
Vijos 1067Warcraft III 守望者的烦恼
查看>>
SQL语句
查看>>
LinkedList
查看>>
Python number
查看>>
【Lv1-Lesson008】A Guide to Birthdays
查看>>