PHP字符串加密解密函数(带时效限制)

2024-01-21 13:48

本文主要是介绍PHP字符串加密解密函数(带时效限制),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

大牛们总是能深入的了解到一些东西,比如下面这篇文章,从DZ中挖掘出一个好用的函数。围观之…

最近, 从discuz里面发现了一个很牛的加密解密函数。

此函数的厉害之处在于可以在指定时间内加密还原字符串,超时无法还这样我们就可以拿此函数来做很多用途了,比如:单点登录的token加密传输啦,临时密码啦等等

 

01<?php
02/**
03  * @param string $string 原文或者密文
04  * @param string $operation 操作(ENCODE | DECODE), 默认为 DECODE
05  * @param string $key 密钥
06  * @param int $expiry 密文有效期, 加密时候有效, 单位 秒,0 为永久有效
07  * @return string 处理后的 原文或者 经过 base64_encode 处理后的密文
08  *
09     * @example
10     *
11     *  $a = authcode('abc', 'ENCODE', 'key');
12     *  $b = authcode($a, 'DECODE', 'key');  // $b(abc)
13     *
14     *  $a = authcode('abc', 'ENCODE', 'key', 3600);
15     *  $b = authcode('abc', 'DECODE', 'key'); // 在一个小时内,$b(abc),否则 $b 为空
16*/
17  
18function authcode($string, $operation = 'DECODE', $key = '', $expiry = 3600) {
19    $ckey_length = 4;  
20    // 随机密钥长度 取值 0-32;
21    // 加入随机密钥,可以令密文无任何规律,即便是原文和密钥完全相同,加密结果也会每次不同,增大破解难度。
22    // 取值越大,密文变动规律越大,密文变化 = 16 的 $ckey_length 次方
23    // 当此值为 0 时,则不产生随机密钥
24  
25    $key = md5($key ? $key : EABAX::getAppInf('KEY'));
26    $keya = md5(substr($key, 0, 16));
27    $keyb = md5(substr($key, 16, 16));
28    $keyc = $ckey_length ? ($operation == 'DECODE' ? substr($string, 0, $ckey_length): substr(md5(microtime()), -$ckey_length)) : '';
29  
30    $cryptkey = $keya.md5($keya.$keyc);
31    $key_length = strlen($cryptkey);
32  
33    $string = $operation == 'DECODE' ? base64_decode(substr($string, $ckey_length)) : sprintf('%010d', $expiry ? $expiry + time() : 0).substr(md5($string.$keyb), 0, 16).$string;
34    $string_length = strlen($string);
35  
36    $result = '';
37    $box = range(0, 255);
38  
39    $rndkey = array();
40    for($i = 0; $i <= 255; $i++) {
41        $rndkey[$i] = ord($cryptkey[$i % $key_length]);
42    }
43  
44    for($j = $i = 0; $i < 256; $i++) {
45        $j = ($j + $box[$i] + $rndkey[$i]) % 256;
46        $tmp = $box[$i];
47        $box[$i] = $box[$j];
48        $box[$j] = $tmp;
49    }
50  
51    for($a = $j = $i = 0; $i < $string_length; $i++) {
52        $a = ($a + 1) % 256;
53        $j = ($j + $box[$a]) % 256;
54        $tmp = $box[$a];
55        $box[$a] = $box[$j];
56        $box[$j] = $tmp;
57        $result .= chr(ord($string[$i]) ^ ($box[($box[$a] + $box[$j]) % 256]));
58    }
59  
60    if($operation == 'DECODE') {
61        if((substr($result, 0, 10) == 0 || substr($result, 0, 10) - time() > 0) && substr($result, 10, 16) == substr(md5(substr($result, 26).$keyb), 0, 16)) {
62            return substr($result, 26);
63        } else {
64            return '';
65        }
66    } else {
67        return $keyc.str_replace('=', '', base64_encode($result));
68    }
69  
70}

这篇关于PHP字符串加密解密函数(带时效限制)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/629747

相关文章

hdu1171(母函数或多重背包)

题意:把物品分成两份,使得价值最接近 可以用背包,或者是母函数来解,母函数(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v) 其中指数为价值,每一项的数目为(该物品数+1)个 代码如下: #include<iostream>#include<algorithm>

poj 2135 有流量限制的最小费用最大流

题意: 农场里有n块地,其中约翰的家在1号地,二n号地有个很大的仓库。 农场有M条道路(双向),道路i连接着ai号地和bi号地,长度为ci。 约翰希望按照从家里出发,经过若干块地后到达仓库,然后再返回家中的顺序带朋友参观。 如果要求往返不能经过同一条路两次,求参观路线总长度的最小值。 解析: 如果只考虑去或者回的情况,问题只不过是无向图中两点之间的最短路问题。 但是现在要去要回

poj 3422 有流量限制的最小费用流 反用求最大 + 拆点

题意: 给一个n*n(50 * 50) 的数字迷宫,从左上点开始走,走到右下点。 每次只能往右移一格,或者往下移一格。 每个格子,第一次到达时可以获得格子对应的数字作为奖励,再次到达则没有奖励。 问走k次这个迷宫,最大能获得多少奖励。 解析: 拆点,拿样例来说明: 3 2 1 2 3 0 2 1 1 4 2 3*3的数字迷宫,走两次最大能获得多少奖励。 将每个点拆成两个

poj 2195 bfs+有流量限制的最小费用流

题意: 给一张n * m(100 * 100)的图,图中” . " 代表空地, “ M ” 代表人, “ H ” 代表家。 现在,要你安排每个人从他所在的地方移动到家里,每移动一格的消耗是1,求最小的消耗。 人可以移动到家的那一格但是不进去。 解析: 先用bfs搞出每个M与每个H的距离。 然后就是网络流的建图过程了,先抽象出源点s和汇点t。 令源点与每个人相连,容量为1,费用为

poj 3068 有流量限制的最小费用网络流

题意: m条有向边连接了n个仓库,每条边都有一定费用。 将两种危险品从0运到n-1,除了起点和终点外,危险品不能放在一起,也不能走相同的路径。 求最小的费用是多少。 解析: 抽象出一个源点s一个汇点t,源点与0相连,费用为0,容量为2。 汇点与n - 1相连,费用为0,容量为2。 每条边之间也相连,费用为每条边的费用,容量为1。 建图完毕之后,求一条流量为2的最小费用流就行了

C++操作符重载实例(独立函数)

C++操作符重载实例,我们把坐标值CVector的加法进行重载,计算c3=c1+c2时,也就是计算x3=x1+x2,y3=y1+y2,今天我们以独立函数的方式重载操作符+(加号),以下是C++代码: c1802.cpp源代码: D:\YcjWork\CppTour>vim c1802.cpp #include <iostream>using namespace std;/*** 以独立函数

函数式编程思想

我们经常会用到各种各样的编程思想,例如面向过程、面向对象。不过笔者在该博客简单介绍一下函数式编程思想. 如果对函数式编程思想进行概括,就是f(x) = na(x) , y=uf(x)…至于其他的编程思想,可能是y=a(x)+b(x)+c(x)…,也有可能是y=f(x)=f(x)/a + f(x)/b+f(x)/c… 面向过程的指令式编程 面向过程,简单理解就是y=a(x)+b(x)+c(x)

Java 后端接口入参 - 联合前端VUE 使用AES完成入参出参加密解密

加密效果: 解密后的数据就是正常数据: 后端:使用的是spring-cloud框架,在gateway模块进行操作 <dependency><groupId>com.google.guava</groupId><artifactId>guava</artifactId><version>30.0-jre</version></dependency> 编写一个AES加密

每日一题|牛客竞赛|四舍五入|字符串+贪心+模拟

每日一题|四舍五入 四舍五入 心有猛虎,细嗅蔷薇。你好朋友,这里是锅巴的C\C++学习笔记,常言道,不积跬步无以至千里,希望有朝一日我们积累的滴水可以击穿顽石。 四舍五入 题目: 牛牛发明了一种新的四舍五入应用于整数,对个位四舍五入,规则如下 12345->12350 12399->12400 输入描述: 输入一个整数n(0<=n<=109 ) 输出描述: 输出一个整数

利用matlab bar函数绘制较为复杂的柱状图,并在图中进行适当标注

示例代码和结果如下:小疑问:如何自动选择合适的坐标位置对柱状图的数值大小进行标注?😂 clear; close all;x = 1:3;aa=[28.6321521955954 26.2453660695847 21.69102348512086.93747104431360 6.25442246899816 3.342835958564245.51365061796319 4.87