PHP中加密解密函数与DES加密解密

我了解中的php加密与解密方法有很多的,有常用的encrypt与DES加密解密算法了,下面我就给大家整理这两种算法的加密函数例子.

例子,php加密解密的例子,代码如下:

  1. /*
  2. *功能:对字符串进行加密处理
  3. *参数一:需要加密的内容
  4. *参数二:密钥
  5. */
  6. function passport_encrypt($str,$key){ //加密函数
  7. srand((double)microtime() * 1000000);
  8. $encrypt_key=md5(rand(0, 32000));
  9. $ctr=0;
  10. $tmp='';
  11. for($i=0;$i<strlen($str);$i++){
  12. $ctr=$ctr==strlen($encrypt_key)?0:$ctr;
  13. $tmp.=$encrypt_key[$ctr].($str[$i] ^ $encrypt_key[$ctr++]);
  14. }
  15. return base64_encode(passport_key($tmp,$key));
  16. }

解密代码如下:

  1. /*
  2. *功能:对字符串进行解密处理
  3. *参数一:需要解密的密文
  4. *参数二:密钥
  5. */
  6. function passport_decrypt($str,$key){ //解密函数
  7. $str=passport_key(base64_decode($str),$key);
  8. $tmp='';
  9. for($i=0;$i<strlen($str);$i++){
  10. $md5=$str[$i];
  11. $tmp.=$str[++$i] ^ $md5;
  12. }//开源代码phpfensi.com
  13. return $tmp;
  14. }

辅助函数:

  1. /*
  2. *辅助函数
  3. */
  4. function passport_key($str,$encrypt_key){
  5. $encrypt_key=md5($encrypt_key);
  6. $ctr=0;
  7. $tmp='';
  8. for($i=0;$i<strlen($str);$i++){
  9. $ctr=$ctr==strlen($encrypt_key)?0:$ctr;
  10. $tmp.=$str[$i] ^ $encrypt_key[$ctr++];
  11. }
  12. return $tmp;
  13. }

使用如下所示:

  1. $str='作者:www.phpfensi.com';
  2. $key='123456';
  3. $encrypt=passport_encrypt($str,$key);
  4. $decrypt=passport_decrypt($encrypt,$key);
  5. echo '原文:',$str."<br><hr>";
  6. echo '密文:',$encrypt."<br><hr>";
  7. echo '译文:',$decrypt."<br><hr>";

DES加密解密函数,代码如下:

  1. <?php
  2. class DES
  3. {
  4. var $key;
  5. var $iv; //偏移量
  6. function DES( $key, $iv=0 ) {
  7. //key长度8例如:1234abcd
  8. $this->key = $key;
  9. if( $iv == 0 ) {
  10. $this->iv = $key;
  11. } else {
  12. $this->iv = $iv; //mcrypt_create_iv ( mcrypt_get_block_size (MCRYPT_DES, MCRYPT_MODE_CBC), MCRYPT_DEV_RANDOM );
  13. }
  14. }
  15. function encrypt($str) {
  16. //加密,返回大写十六进制字符串
  17. $size = mcrypt_get_block_size ( MCRYPT_DES, MCRYPT_MODE_CBC );
  18. $str = $this->pkcs5Pad ( $str, $size );
  19. return strtoupper( bin2hex( mcrypt_cbc(MCRYPT_DES, $this->key, $str, MCRYPT_ENCRYPT, $this->iv ) ) );
  20. }
  21. function decrypt($str) {
  22. //解密
  23. $strBin = $this->hex2bin( strtolower( $str ) );
  24. $str = mcrypt_cbc( MCRYPT_DES, $this->key, $strBin, MCRYPT_DECRYPT, $this->iv );
  25. $str = $this->pkcs5Unpad( $str );
  26. return $str;
  27. }
  28. function hex2bin($hexData) {
  29. $binData = "";
  30. for($i = 0; $i < strlen ( $hexData ); $i += 2) {
  31. $binData .= chr ( hexdec ( substr ( $hexData, $i, 2 ) ) );
  32. }
  33. return $binData;
  34. }
  35. function pkcs5Pad($text, $blocksize) {
  36. $pad = $blocksize - (strlen ( $text ) % $blocksize);
  37. return $text . str_repeat ( chr ( $pad ), $pad );
  38. }
  39. function pkcs5Unpad($text) {
  40. $pad = ord ( $text {strlen ( $text ) - 1} );
  41. if ($pad > strlen ( $text ))
  42. return false;
  43. if (strspn ( $text, chr ( $pad ), strlen ( $text ) - $pad ) != $pad)
  44. return false;
  45. return substr ( $text, 0, - 1 * $pad );
  46. }
  47. }
  48. ?>
  49. //以下是测试结果:
  50. $str = '12345678';
  51. $key = '1234abcd';
  52. $crypt = new DES($key);
  53. $mstr = $crypt->encrypt($str);
  54. $str = $crypt->decrypt($mstr);
  55. echo $str.' <=> '.$mstr;

例子2,代码如下:

  1. /**
  2. *加密需通过get方式在url中传递的参数
  3. */
  4. function args_encode($data) {
  5. if(is_array($data)) {
  6. $string = http_build_query($data);
  7. return base64_encode($string);
  8. } else {
  9. return false;
  10. }
  11. }
  12. /**
  13. *获取url中get方式传递的参数
  14. */
  15. function getargs() {
  16. $string = base64_decode($_GET['args']);
  17. parse_str($string,$g);
  18. return $g;
  19. }