各种加密解密函数(URL加密解密、sha1加密解密、des加密解密)

普通hash函数如md5、sha1、base64等都是不可逆函数。虽然我们利用php可以利用这些函数写出可逆函数来。但是跨语言时这类可逆函数非常难搞定。所以这时尽量使用AES DES RC4 Rabbit TripleDes这些方法。

包含超时的加密解密函数

 1 /**
 2     * 加密
 3     * @param string $string     要加密或解密的字符串
 4     * @param string $operation 加密 ‘‘  解密 DECODE
 5     * @param string $key        密钥,加密解密时保持一致
 6     * @param int    $expiry 有效时长,单位:秒
 7     * @return string
 8     */
 9     function encrypt_code($string, $expiry = 0, $key = ‘abc12345‘) {
10     $ckey_length = 7;
11     $key = md5($key ? $key : UC_KEY); //加密解密时这个是不变的
12     $keya = md5(substr($key, 0, 16)); //加密解密时这个是不变的
13     $keyb = md5(substr($key, 16, 16)); //加密解密时这个是不变的
14     $keyc = $ckey_length ?  substr(md5(microtime()), -$ckey_length) : ‘‘;
15     $cryptkey = $keya . md5($keya . $keyc); //64
16     $key_length = strlen($cryptkey); //64
17
18     $string =sprintf(‘%010d‘, $expiry ? $expiry + time() : 0) . substr(md5($string . $keyb), 0, 16) . $string;
19     $string_length = strlen($string);
20
21     $result = ‘‘;
22     $box = range(0, 255);
23
24     $rndkey = array();
25     for ($i = 0; $i <= 255; $i++) { //字母表 64位后重复 数列 范围为48~122
26         $rndkey[$i] = ord($cryptkey[$i % $key_length]);
27     }
28
29     for ($j = $i = 0; $i < 256; $i++) { //这里是一个打乱算法
30         $j = ($j + $box[$i] + $rndkey[$i]) % 256;
31         $tmp = $box[$i];
32         $box[$i] = $box[$j];
33         $box[$j] = $tmp;
34     }
35     for ($a = $j = $i = 0; $i < $string_length; $i++) {
36         $result .= chr(ord($string[$i]) ^ ($box[$i]));
37
38     }
39      $str =  $keyc . str_replace(‘=‘, ‘‘, urlsafe_b64encode($result));
40                 //  $str =htmlentities($str, ENT_QUOTES, "UTF-8"); // curl 访问出错
41                   return $str ;
42 }
43
44
45    /**
46     * 解密
47     * @param string $string     要加密或解密的字符串
48     * @param string $operation 加密 ‘‘  解密 DECODE
49     * @param string $key        密钥,加密解密时保持一致
50     * @param int    $expiry 有效时长,单位:秒
51     * @return string
52     */
53      function encrypt_decode($string, $expiry = 0,$key = ‘abc12345‘) {
54                             //  $string = html_entity_decode($string, ENT_QUOTES, "UTF-8") ; //curl 访问出错
55     $ckey_length = 7;
56     $key = md5($key ? $key : UC_KEY); //加密解密时这个是不变的
57     $keya = md5(substr($key, 0, 16)); //加密解密时这个是不变的
58     $keyb = md5(substr($key, 16, 16)); //加密解密时这个是不变的
59
60     $keyc = $ckey_length ?  substr($string, 0, $ckey_length)   : ‘‘;
61
62     $cryptkey = $keya . md5($keya . $keyc); //64
63     $key_length = strlen($cryptkey); //64
64     $string = urlsafe_b64decode(substr($string, $ckey_length)) ;
65                $string_length = strlen($string);
66     $result = ‘‘;
67     $box = range(0, 255);
68
69     $rndkey = array();
70     for ($i = 0; $i <= 255; $i++) { //字母表 64位后重复 数列 范围为48~122
71         $rndkey[$i] = ord($cryptkey[$i % $key_length]);
72     }
73     for ($j = $i = 0; $i < 256; $i++) { //这里是一个打乱算法
74         $j = ($j + $box[$i] + $rndkey[$i]) % 256;
75
76         $tmp = $box[$i];
77         $box[$i] = $box[$j];
78         $box[$j] = $tmp;
79     }
80     for ($a = $j = $i = 0; $i < $string_length; $i++) {
81         $result .= chr(ord($string[$i]) ^ ($box[$i]));
82     }
83           if ((substr($result, 0, 10) == 0 || substr($result, 0, 10) - time() > 0) && substr($result, 10, 16) == substr(md5(substr($result, 26) . $keyb), 0, 16)) {
84                        return substr($result, 26);
85                } else {
86                        return false;
87                }
88
89 }  

最简单的往往是最好用的。

URL加密解密函数

 1     //加密函数
 2     function lock_url($txt,$key=‘www.zhuoyuexiazai.com‘){
 3         $chars = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-=+";
 4         $nh = rand(0,64);
 5         $ch = $chars[$nh];
 6         $mdKey = md5($key.$ch);
 7         $mdKey = substr($mdKey,$nh%8, $nh%8+7);
 8         $txt = base64_encode($txt);
 9         $tmp = ‘‘;
10         $i=0;$j=0;$k = 0;
11         for ($i=0; $i<strlen($txt); $i++) {
12             $k = $k == strlen($mdKey) ? 0 : $k;
13             $j = ($nh+strpos($chars,$txt[$i])+ord($mdKey[$k++]))%64;
14             $tmp .= $chars[$j];
15         }
16         return urlencode($ch.$tmp);
17     }
18     //解密函数
19     function unlock_url($txt,$key=‘www.zhuoyuexiazai.com‘){
20         $txt = urldecode($txt);
21         $chars = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-=+";
22         $ch = $txt[0];
23         $nh = strpos($chars,$ch);
24         $mdKey = md5($key.$ch);
25         $mdKey = substr($mdKey,$nh%8, $nh%8+7);
26         $txt = substr($txt,1);
27         $tmp = ‘‘;
28         $i=0;$j=0; $k = 0;
29         for ($i=0; $i<strlen($txt); $i++) {
30             $k = $k == strlen($mdKey) ? 0 : $k;
31             $j = strpos($chars,$txt[$i])-$nh - ord($mdKey[$k++]);
32             while ($j<0) $j+=64;
33             $tmp .= $chars[$j];
34         }
35         return base64_decode($tmp);
36     }  

用户密码可逆加密解密函数:

 1     <?php
 2     function passport_encrypt($txt, $key = ‘www.zhuoyuexiazai.com‘) {
 3         srand((double)microtime() * 1000000);
 4         $encrypt_key = md5(rand(0, 32000));
 5         $ctr = 0;
 6         $tmp = ‘‘;
 7         for($i = 0;$i < strlen($txt); $i++) {
 8         $ctr = $ctr == strlen($encrypt_key) ? 0 : $ctr;
 9         $tmp .= $encrypt_key[$ctr].($txt[$i] ^ $encrypt_key[$ctr++]);
10         }
11         return urlencode(base64_encode(passport_key($tmp, $key)));
12     }
13
14     function passport_decrypt($txt, $key = ‘www.zhuoyuexiazai.com‘) {
15         $txt = passport_key(base64_decode(urldecode($txt)), $key);
16         $tmp = ‘‘;
17         for($i = 0;$i < strlen($txt); $i++) {
18         $md5 = $txt[$i];
19         $tmp .= $txt[++$i] ^ $md5;
20         }
21         return $tmp;
22     }
23
24     function passport_key($txt, $encrypt_key) {
25         $encrypt_key = md5($encrypt_key);
26         $ctr = 0;
27         $tmp = ‘‘;
28         for($i = 0; $i < strlen($txt); $i++) {
29         $ctr = $ctr == strlen($encrypt_key) ? 0 : $ctr;
30         $tmp .= $txt[$i] ^ $encrypt_key[$ctr++];
31         }
32         return $tmp;
33     }
34     ?>  

测试方法:

1     <?php
2     $txt = "1";
3     $key = "testkey";
4     $encrypt = passport_encrypt($txt,$key);
5     $decrypt = passport_decrypt($encrypt,$key);
6
7     echo $encrypt."<br>";
8     echo $decrypt."<br>";
9     ?>   

SHA1的可逆加密解密函数:

 1     <?php
 2     $string = "Helloworld";
 3     echo $str1 = dencrypt($string, true, "www.miaohr.com");
 4     echo $str2 = dencrypt($str1, false, "www.miaohr.com");
 5
 6     function dencrypt($string, $isEncrypt = true, $key = KEY_SPACE) {
 7     if (!isset($string{0}) || !isset($key{0})) {
 8     return false;
 9     }
10
11     $dynKey = $isEncrypt ? hash(‘sha1‘, microtime(true)) : substr($string, 0, 40);
12     $fixedKey = hash(‘sha1‘, $key);
13
14     $dynKeyPart1 = substr($dynKey, 0, 20);
15     $dynKeyPart2 = substr($dynKey, 20);
16     $fixedKeyPart1 = substr($fixedKey, 0, 20);
17     $fixedKeyPart2 = substr($fixedKey, 20);
18     $key = hash(‘sha1‘, $dynKeyPart1 . $fixedKeyPart1 . $dynKeyPart2 . $fixedKeyPart2);
19
20     $string = $isEncrypt ? $fixedKeyPart1 . $string . $dynKeyPart2 : (isset($string{339}) ? gzuncompress(base64_decode(substr($string, 40))) : base64_decode(substr($string, 40)));
21
22     $n = 0;
23     $result = ‘‘;
24     $len = strlen($string);
25
26     for ($n = 0; $n < $len; $n++) {
27     $result .= chr(ord($string{$n}) ^ ord($key{$n % 40}));
28     }
29     return $isEncrypt ? $dynKey . str_replace(‘=‘, ‘‘, base64_encode($n > 299 ? gzcompress($result) : $result)) : substr($result, 20, -20);
30     }
31
32     ?>  

DES的加密解密函数:

 1     <?php
 2
 3     $input =‘http://mlaan2.home.xs4all.nl/ispack/isetup-5.5.3.exe‘;
 4      /**
 5     *加密函数
 6     *$input 要被加密的字符串
 7     *$key 密钥
 8     */
 9
10     $key = randomkeys(8);//生成随机密匙
11     function do_mencrypt($input, $key)
12     {
13         $input = base64_encode(trim($input));
14         //$key = substr(md5($key), 0, 4);
15         $td = mcrypt_module_open(‘des‘, ‘‘, ‘ecb‘, ‘‘);
16         $iv = mcrypt_create_iv(mcrypt_enc_get_iv_size($td), MCRYPT_RAND);
17         mcrypt_generic_init($td, $key, $iv);
18         $encrypted_data = mcrypt_generic($td, $input);
19         mcrypt_generic_deinit($td);
20         mcrypt_module_close($td);
21         return trim(base64_encode($encrypted_data));
22     }
23     print_r(do_mencrypt($input, $key));
24     echo "<br/>";
25     /**
26     *解密函数
27     *$input 要被解密的字符串
28     *$key 密钥
29     */
30     $input1 = do_mencrypt($input, $key);
31     function do_mdecrypt($input1, $key)
32     {
33         $input1 = base64_decode(trim($input1));
34         $td = mcrypt_module_open(‘des‘, ‘‘, ‘ecb‘, ‘‘);
35         //$key = substr(md5($key), 0, 4);
36         $iv = mcrypt_create_iv(mcrypt_enc_get_iv_size($td), MCRYPT_RAND);
37         mcrypt_generic_init($td, $key, $iv);
38         $decrypted_data = mdecrypt_generic($td, $input1);
39         mcrypt_generic_deinit($td);
40         mcrypt_module_close($td);
41         return trim(base64_decode($decrypted_data));
42     }
43     print_r(do_mdecrypt($input1, $key));
44
45      #2.rand key: "CWSTOAYD":生成随机密匙,统一用字母或者数字,长度为8.
46     function randomkeys($length)
47     {
48        $pattern = ‘1234567890‘;
49         for($i=0;$i<$length;$i++)
50         {
51             @$key .= $pattern{rand(0,9)};    //生成php随机数
52         }
53         return $key;
54     }
55     ?>  

如果你感觉这些内容对你有帮助,那就收藏他吧。

时间: 2024-10-13 15:58:01

各种加密解密函数(URL加密解密、sha1加密解密、des加密解密)的相关文章

PHP带参数可逆的加密解密函数,可用于cookie的加密解密

在开发应用过程中我们经常会涉及一些链接或参数或cookie的加密解密,由于php自身提供的md5函数不可逆,因此md5只适用于类似密码加密的地方,而cookie加密则有局限性,下面为大家提供一种加密解密函数方法,供大家参考: <?php //加密函数 function passport_encrypt($txt, $key) { srand((double)microtime() * 1000000); $encrypt_key = md5(rand(0, 32000)); $ctr = 0;

JavaScript与C#互通的DES加解密算法

原文地址:传送门 本文提供了一个能使JavaScript与C#互通的DES加解密算法的实现,在前台页面中用JavaScript版本的DES算法将数据加密之后,传到服务器端,在服务器端可用C#版本的DES解密算法将其解密,得到原始数据,以起到一定的保密作用.但基于算法本身和密钥保密程度方面的考虑,使用本算法加密后的数据,其保密程度不是很高,故请酌情使用. 声明:本文中的JavaScript版的DES加解密算法来自于互联网,但为了方便于转化成C#版本的代码,本人对其进行了细微调整. JavaScri

对称加密——对入参进行DES加密处理

体验更优排版请移步原文:http://vblog.win/blogs/programming/symmetric-encryption-des-js-java.html 对称加密是最快速.最简单的一种加密方式,加密和解密共用一个对称秘钥,因其高效性,被广泛应用在加密协议中.今天恰巧用到,在此总结一下. 我们项目中需要在前端js里对入参进行DES加密传入后台,后台java再进行解密,网上找了一个谷歌的DES加密js包crypto-js,点此下载 下载完成之后找到两个js文件引入项目工程中, 1 2

一个java的DES加解密类转换成C#

原文:一个java的DES加解密类转换成C# 一个java的des加密解密代码如下: //package com.visionsky.util; import java.security.*; //import java.util.regex.Pattern; //import java.util.Hashtable; import javax.crypto.*; import javax.crypto.spec.*; import sun.misc.*; /** * des加密解密 */ pu

Android客户端与服务器端通过DES加密认证

转载地址:http://blog.csdn.net/spring21st/article/details/6730283 由于Android应用没有像web开发中的session机制,所以采用PHPSESSID的方式,是没有办法获取客户端登录状态的. 这种情况下,如何在用户登录后,服务器端获取用户登录状态并保持,就必须采用一种“握手”的方式. 每个手机都有自己的IMEI号,那么能不能通过这个标识去做认证呢? 经过试验,答案是可以! 客户端在请求服务器端的时候,请求参数为 IMEI (param

php的加密解密函数

计应134(实验班)詹加全 在网站的开发过程中,常常需要对部分数据(如用户密码)进行加密,本文主要介绍PHP的几个常见的加密函数 MD5加密: string md5 ( string $str [, bool $raw_output = false ] ) 1.md5()默认情况下以 32 字符十六进制数字形式返回散列值,它接受两个参数,第一个为要加密的字符串,第二个为raw_output的布尔值,默认为false,如果设置为true,md5()则会返回原始的 16 位二进制格式报文摘要 2.m

介绍几个PHP 自带的加密解密函数

目前经常使用的加密函数有:md5(), sha1(), crypt(), base64_encode(), urlencode() .其中 md5(), sha1(), crypt() 是不可逆的加密方式.base64_encode() ,urlencode() 是可逆的加密方式.分别对应的解密函数为:base64_decode(), urldecode(). 使用方法: $str = '要加密的字符串'; // md5 加密 $md5 = md5($str); echo $md5 . '</b

Oracle定义DES加密解密及MD5加密函数

http://blog.csdn.net/xdweleven/article/details/38319351 (1)DES加密函数create or replace functionencrypt_des(p_text varchar2, p_key varchar2) return varchar2 is        v_text varchar2(4000);        v_enc varchar2(4000);        raw_input RAW(128) ;       

php加密解密函数

转自:http://www.jb51.net/article/51706.htm 很多项目的会员系统,都要求要有记住登录功能,在通过cookies实现功能是,由于要将客户信息直接保存到cookies,如果直接写入cookies势必会带来安全隐患,因此通过可逆加密后再保存到cookies相对就安全了 项目中有时我们需要使用PHP将特定的信息进行加密,也就是通过加密算法生成一个加密字符串,这个加密后的字符串可以通过解密算法进行解密,便于程序对解密后的信息进行处理.最常见的应用在用户登录以及一些API