您现在的位置是:首页 > 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、代码解析
设计原理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 }
本文标签:
很赞哦! ()
相关教程
图文教程
Discuz导航和静态化URL设置方法
规范化目录即为URL后面添加斜杠/之前用ISAPI_Rewrite在IIS中伪静态不规范化目录也不会出现链接错误(为了SEO一般是范化目录的规则为:
Discuz!X2 、Ucenter 1.6、ASP.NET程序整合步骤
对于ASP.NET 程序员来说,去整合PHP的应用实在有点别扭,但那也没有办法,即然是做程序的这些是避免不了的,既然免不了,那就上吧第一步:准备相关程序
Discuz<= 7.2 SQL注入漏洞分析
Discuz树大招风已成常态,不过对于其他整站程序何尝不是如此?是否曾记得大明湖畔的PHPCMS和DEDCMS万人破的场景,流行整站程序最重要的还是漏洞的快速响应。0x01 漏洞成因:
discuz去掉portal.php的方法
discuz去掉“portal.php”的方法:首先在系统后台的导航设置中将默认的首页设置为“不可用”;然后打开“index.php”并修改内容为“$_ENV['domain']['defaultindex']”即可。
相关源码
-
(自适应html5)重工业钢铁机械设备网站pbootcms响应式模板下载为重工业领域打造的响应式网站模板,助力企业高效展示产品与服务,基于PbootCMS开发的工业级网站模板,特别适合钢铁制造、机械设备生产等重工业企业使用。查看源码 -
(自适应)帝国cms7.5文章新闻博客整站源码( 带会员中心)本模板基于帝国CMS内核开发,为新闻资讯、个人博客及作品展示类网站设计。采用响应式布局技术,确保在手机、平板和电脑等不同设备上都能获得良好的浏览体验。查看源码 -
(自适应)高端集团跨国公司产业联盟机构网站模板免费下载基于PbootCMS内核开发的集团级企业网站模板,采用响应式设计架构,确保在各类移动设备上获得浏览体验。通过模块化布局与简约大气的视觉风格,帮助集团企业高效展示组织架构、发展历程和业务矩阵,建立专业的企业形象窗口。查看源码 -
(自适应)文案文档作文写作word资源网站模板下载本模板基于PbootCMS系统深度开发,针对电影解说、文案分享类网站的特殊需求设计。采用响应式布局技术,确保在手机端和桌面端都能呈现专业的内容展示效果,帮助运营者高效管理影视解说资源。查看源码 -
帝国cms7.5个人博客资讯文章模板下载本模板简洁个人博客网站设计开发,采用帝国CMS内核构建,只需替换文字图片即可快速搭建专业网站。自适应手机端设计,数据实时同步,操作简单便捷。PHP程序确保安全稳定运行,帮助您以较低成本获取持续业务。查看源码 -
(自适应响应式)化妆美容口红唇膏化妆品模板pbootcms源码下载基于PbootCMS开发的响应式模板,为化妆品品牌、美容机构打造,通过优雅的视觉呈现提升产品展示效果与品牌调性。采用时尚杂志排版风格,色卡系统规范产品展示。微交互动画增强用户体验,智能推荐算法提升产品关联展示效果。查看源码
| 分享笔记 (共有 篇笔记) |
