您现在的位置是:首页 > cms教程 > Discuz教程Discuz教程

discuz的PHP加解密算法函数介绍

海莲2025-07-20Discuz教程已有人查阅

导读authcode函数很牛叉,是一个具有有效期的加解密函数,同一个字符每次加密所产生的结果都是不一致的,并且可以自定义设置过期时间。设计原理authcode是使用异或运算进行加密和解

authcode函数很牛叉,是一个具有有效期的加解密函数,同一个字符每次加密所产生的结果都是不一致的,并且可以自定义设置过期时间。
设计原理authcode是使用异或运算进行加密和解密。
加密
明文:1010 1001
密匙:1110 0011
密文:0100 1010
得出密文0100 1010,解密之需和密匙异或下就可以了
解密
密文:0100 1010
密匙:1110 0011
明文:1010 1001
并没有什么高深的算法,密匙重要性很高,所以,关键在于怎么生成密匙。
2、代码解析
1 <?php
2
3 /**
4 * @param string $string 原文或者密文
5 * @param string $operation 操作(ENCODE | DECODE), 默认为 DECODE
6 * @param string $key 密钥
7 * @param int $expiry 密文有效期, 加密时候有效, 单位 秒,0 为长久有效
8 * @return string 处理后的 原文或者 经过 base64_encode 处理后的密文
9 *************************
10 * @example
11 *
12 * $a = authcode('abc', 'ENCODE', 'key');
13 * $b = authcode($a, 'DECODE', 'key'); // $b(abc)
14 *
15 * $a = authcode('abc', 'ENCODE', 'key', 3600);
16 * $b = authcode('abc', 'DECODE', 'key'); // 在一个小时内,$b(abc),否则 $b 为空
17 */
18 function authcode($string, $operation = 'DECODE', $key = '', $expiry = 3600) {
19
20 // 随机密钥长度 取值 0-32;
21 // 加入随机密钥,可以令密文无任何规律,即便是原文和密钥完全相同,加密结果也会每次不同,增大破解难度。
22 // 取值越大,密文变动规律越大,密文变化 = 16 的 $ckey_length 次方
23 // 当此值为 0 时,则不产生随机密钥
24 $ckey_length = 4;
25
26 $key = md5($key ? $key : 'default_key'); // 这里可以填写默认key值
27 $keya = md5(substr($key, 0, 16)); // 密匙a会参与加解密 [keya = md5 新key前16位]
28 $keyb = md5(substr($key, 16, 16)); // 密匙b会用来做数据完整性验证 [keyb = md5 新key后16位]
29 // 密匙c用于变化生成的密文
30 // 加密:keyc = 当前时间毫秒做md5加密,截取末尾随机秘钥长度字符
31 // 解密:keyc = 截取传入的字符串string末尾随机秘钥长度字符
32 $keyc = $ckey_length ? ($operation == 'DECODE' ? substr($string, 0, $ckey_length): substr(md5(microtime()), -$ckey_length)) : '';
33 // 参与运算的密匙
34 $cryptkey = $keya.md5($keya.$keyc);
35 $key_length = strlen($cryptkey);
36
37 // 明文,前10位用来保存时间戳,解密时验证数据有效性,10到26位用来保存$keyb(密匙b),解密时会通过这个密匙验证数据完整性
38 // 如果是解码的话,会从第$ckey_length位开始,因为密文前$ckey_length位保存 动态密匙,以保证解密正确
39 $string = $operation == 'DECODE' ? base64_decode(substr($string, $ckey_length)) : sprintf('%010d', $expiry ? $expiry + time() : 0).substr(md5($string.$keyb), 0, 16).$string;
40 $string_length = strlen($string);
41 $result = '';
42 $box = range(0, 255);
43
44 $rndkey = array();
45 // 产生密匙簿
46 for($i = 0; $i <= 255; $i++) {
47 $rndkey[$i] = ord($cryptkey[$i % $key_length]);
48 }
49
50 // 用固定的算法,打乱密匙簿,增加随机性,好像很复杂,实际上对并不会增加密文的强度
51 for($j = $i = 0; $i < 256; $i++) {
52 $j = ($j + $box[$i] + $rndkey[$i]) % 256;
53 $tmp = $box[$i];
54 $box[$i] = $box[$j];
55 $box[$j] = $tmp;
56 }
57
58 // 核心加解密部分
59 for($a = $j = $i = 0; $i < $string_length; $i++) {
60 $a = ($a + 1) % 256;
61 $j = ($j + $box[$a]) % 256;
62 $tmp = $box[$a];
63 $box[$a] = $box[$j];
64 $box[$j] = $tmp;
65 // 从密匙簿得出密匙进行异或,再转成字符
66 $result .= chr(ord($string[$i]) ^ ($box[($box[$a] + $box[$j]) % 256]));
67 }
68
69 if($operation == 'DECODE') {
70 // substr($result, 0, 10) == 0 验证数据有效性
71 // substr($result, 0, 10) - time() > 0 验证数据有效性
72 // substr($result, 10, 16) == substr(md5(substr($result, 26).$keyb), 0, 16) 验证数据完整性
73 // 验证数据有效性,请看未加密明文的格式
74 if((substr($result, 0, 10) == 0 || substr($result, 0, 10) - time() > 0) && substr($result, 10, 16) == substr(md5(substr($result, 26).$keyb), 0, 16)) {
75 return substr($result, 26);
76 } else {
77 return '';
78 }
79 } else {
80 // 把动态密匙保存在密文里,这也是为什么同样的明文,生产不同密文后能解密的原因
81 // 因为加密后的密文可能是一些特殊字符,复制过程可能会丢失,所以用base64编码
82 return $keyc.str_replace('=', '', base64_encode($result));
83 }
84
85 }

本文标签:

很赞哦! ()

相关源码

  • (自适应响应式)英文外贸医疗科研耗材设备pbootcms网站模板为医疗设备和外贸企业设计的响应式网站模板,基于PbootCMS系统开发。突出医疗产品认证展示和国际化特性,通过专业化的产品参数展示模块和文档管理系统,满足医疗行业严格的信息披露要求。查看源码
  • (自适应)高端集团跨国公司产业联盟机构网站模板免费下载基于PbootCMS内核开发的集团级企业网站模板,采用响应式设计架构,确保在各类移动设备上获得浏览体验。通过模块化布局与简约大气的视觉风格,帮助集团企业高效展示组织架构、发展历程和业务矩阵,建立专业的企业形象窗口。查看源码
  • (PC+WAP)pbootcms模板黑色门窗定制五金建材网站下载为门窗定制与五金建材企业设计的网站解决方案,采用PbootCMS开发,兼具专业展示与营销功能。黑色系设计突显工业质感,响应式布局确保在手机、平板等设备上的浏览体验。通过简单的内容替换,也可适用于建材贸易、家具定制等相关行业。查看源码
  • PbootCMS(自适应手机端)智能电话AI机器人网站模板产品概述基于PbootCMS内核开发的智能电话AI机器人网站模板,为语音交互服务场景设计,采用HTML5+CSS3响应式布局技术,实现PC端与移动端数据实时同步展示。模板适用于智能电话查看源码
  • (响应式自适应)小学初中作文论文文章资讯博客pbootcms模板下载为中小学作文、教育类网站设计,特别适合展示学生作文、教学资源和写作指导等内容。采用响应式技术,确保在不同设备上都能获得良好的阅读体验。查看源码
  • (自适应)工业机械制造设备网站pbootcms模板下载为机械制造、工业设备类企业设计,特别适合各类机械设备、生产线、工业自动化产品展示。采用响应式技术,确保在不同设备上都能清晰展示机械产品的技术参数和细节特点。查看源码
分享笔记 (共有 篇笔记)
验证码:

本栏推荐