原文:各种加密解密函数(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. * @param string $string 要加密或解密的字符串
  47. * @param string $operation 加密 '' 解密 DECODE
  48. * @param string $key 密钥,加密解密时保持一致
  49. * @param int $expiry 有效时长,单位:秒
  50. * @return string
  51. */
  52. function encrypt_decode($string, $expiry = 0,$key = 'abc12345') {
  53. // $string = html_entity_decode($string, ENT_QUOTES, "UTF-8") ; //curl 访问出错
  54. $ckey_length = 7;
  55. $key = md5($key ? $key : UC_KEY); //加密解密时这个是不变的
  56. $keya = md5(substr($key, 0, 16)); //加密解密时这个是不变的
  57. $keyb = md5(substr($key, 16, 16)); //加密解密时这个是不变的
  58.  
  59. $keyc = $ckey_length ? substr($string, 0, $ckey_length) : '';
  60.  
  61. $cryptkey = $keya . md5($keya . $keyc); //64
  62. $key_length = strlen($cryptkey); //64
  63. $string = urlsafe_b64decode(substr($string, $ckey_length)) ;
  64. $string_length = strlen($string);
  65. $result = '';
  66. $box = range(0, 255);
  67.  
  68. $rndkey = array();
  69. for ($i = 0; $i <= 255; $i++) { //字母表 64位后重复 数列 范围为48~122
  70. $rndkey[$i] = ord($cryptkey[$i % $key_length]);
  71. }
  72. for ($j = $i = 0; $i < 256; $i++) { //这里是一个打乱算法
  73. $j = ($j + $box[$i] + $rndkey[$i]) % 256;
  74.  
  75. $tmp = $box[$i];
  76. $box[$i] = $box[$j];
  77. $box[$j] = $tmp;
  78. }
  79. for ($a = $j = $i = 0; $i < $string_length; $i++) {
  80. $result .= chr(ord($string[$i]) ^ ($box[$i]));
  81. }
  82. if ((substr($result, 0, 10) == 0 || substr($result, 0, 10) - time() > 0) && substr($result, 10, 16) == substr(md5(substr($result, 26) . $keyb), 0, 16)) {
  83. return substr($result, 26);
  84. } else {
  85. return false;
  86. }
  87.  
  88. }

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

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. ?>

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

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

  1. C#和PHP加密结果一致的DES加密解密算法。php实现和c#一致的DES加密解密

    DES加密算法 des对称加密,是一种比较传统的加密方式,其加密运算.解密运算使用的是同样的密钥,信息的发送者和信息的接收者在进行信息的传输与处理时,必须共同持有该密码(称为对称密码),是一种对称加密 ...

  2. DES加密:8051实现(C语言) & FPGA实现(VHDL+NIOS II)

    本文将利用C语言和VHDL语言分别实现DES加密,并在8051和FPGA上测试. 终于有机会阅读<深入浅出密码学一书>,趁此机会深入研究了DES加密的思想与实现.本文将分为两部分,第一部分 ...

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

    原文地址:传送门 本文提供了一个能使JavaScript与C#互通的DES加解密算法的实现,在前台页面中用JavaScript版本的DES算法将数据加密之后,传到服务器端,在服务器端可用C#版本的DE ...

  4. JavaScript与C#互通的DES加解密算法的实现(转)

    本文提供了一个能使JavaScript与C#互通的DES加解密算法的实现,在前台页面中用JavaScript版本的DES算法将数据加密之后,传到服务器端,在服务器端可用C#版本的DES解密算法将其解密 ...

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

    原文:一个java的DES加解密类转换成C# 一个java的des加密解密代码如下: //package com.visionsky.util; import java.security.*; //i ...

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

    体验更优排版请移步原文:http://blog.kwin.wang/programming/symmetric-encryption-des-js-java.html 对称加密是最快速.最简单的一种加 ...

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

    转载地址:http://blog.csdn.net/spring21st/article/details/6730283 由于Android应用没有像web开发中的session机制,所以采用PHPS ...

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

    PHP 自带的加密解密函数 目前经常使用的加密函数有:md5(), sha1(), crypt(), base64_encode(), urlencode() . 其中 md5(), sha1(), ...

  9. php 自带加密、解密函数

    php 自带的加密函数  不可逆的加密函数为:md5().crypt() md5() 用来计算 MD5 哈稀.语法为:string md5(string str); crypt() 将字符串用 UNI ...

随机推荐

  1. [LeetCode235]Lowest Common Ancestor of a Binary Search Tree

    题目: Given a binary search tree (BST), find the lowest common ancestor (LCA) of two given nodes in th ...

  2. LightOJ1010---Knights in Chessboard (规律题)

    Given an m x n chessboard where you want to place chess knights. You have to find the number of maxi ...

  3. 《Javascript权威指南》13号学习笔记:使用日期和时间

    一.创Date示例 1.Date类的方法和属性是非常不静,故,申请书Date属性和方法之前.必须创建Date类的实例. var date = new Date();  //以当前日期和时间创建实例. ...

  4. 二维码简单Demo

    二维码简单Demo 一.视图 @{ Layout = null; } <!DOCTYPE html> <html> <head> <meta name=&qu ...

  5. HDU 3032 Nim or not Nim? (需求的游戏SG功能)

    意甲冠军:经典Nim游戏转换,给你n礧pi,每个堆栈有pi石头, Alice和Bob轮流石头,意一堆中拿走随意个石子,也能够将某一堆石子分成两个小堆 (每堆石子个数必须不能为0).先拿完者获胜 思路: ...

  6. SenchaTouch2.3.1 正在使用listpaging以及pullrefresh插入 分页演示样品做

    实际上本实施例是相对简单的.自定义PullRefreshFn插头继承Ext.plugin.PullRefresh. 主要是其附加refreshFn下拉监控事件. listpaging么改动.再将这两个 ...

  7. Codeforces Round #107 (Div. 2)---A. Soft Drinking

    Soft Drinking time limit per test 2 seconds memory limit per test 256 megabytes input standard input ...

  8. Java IO的RandomAccessFile的使用(转)

    现有如下的一个需求,向已存在1G数据的txt文本里末尾追加一行文字,内容如下“Lucene是一款非常优秀的全文检索库”.可能大多数朋友会觉得这个需求很easy,说实话,确实easy,然后XXX君开始实 ...

  9. 一张图让你看清Java集合类(Java集合类的总结)

    如今关于Java集合类的文章非常多,可是我近期看到一个非常有意思图片,基本上把Java集合的整体框架都给展现出来了.非常直观. watermark/2/text/aHR0cDovL2Jsb2cuY3N ...

  10. linux下各种文件格式的压缩以及解压缩命令

    From : http://blog.csdn.net/mu0206mu/article/details/17732857 -------------------------------------- ...