php加密解密处理类--参 考:Discuz论坛的passpor
<?php
| 02 | /*=========================================================== |
| 04 | = GPL (The GNU GENERAL PUBLIC LICENSE Version 2, June 1991) |
| 05 | =------------------------------------------------------------ |
| 06 | = 文件名称:cls.sys_crypt.php |
| 09 | = 参 考:Discuz论坛的passport相关函数 |
| 10 | =------------------------------------------------------------ |
| 11 | = Script Written By PHPWMS项目组 |
| 14 | ============================================================*/ |
| 21 | public function __construct($crypt_key) { |
| 22 | $this -> crypt_key = $crypt_key; |
| 25 | public function php_encrypt($txt) { |
| 26 | srand((double)microtime() * 1000000); |
| 27 | $encrypt_key = md5(rand(0,32000)); |
| 30 | for($i = 0;$i<strlen($txt);$i++) { |
| 31 | $ctr = $ctr == strlen($encrypt_key) ? 0 : $ctr; |
| 32 | $tmp .= $encrypt_key[$ctr].($txt[$i]^$encrypt_key[$ctr++]); |
| 34 | return base64_encode(self::__key($tmp,$this -> crypt_key)); |
| 37 | public function php_decrypt($txt) { |
| 38 | $txt = self::__key(base64_decode($txt),$this -> crypt_key); |
| 40 | for($i = 0;$i < strlen($txt); $i++) { |
| 42 | $tmp .= $txt[++$i] ^ $md5; |
| 47 | private function __key($txt,$encrypt_key) { |
| 48 | $encrypt_key = md5($encrypt_key); |
| 51 | for($i = 0; $i < strlen($txt); $i++) { |
| 52 | $ctr = $ctr == strlen($encrypt_key) ? 0 : $ctr; |
| 53 | $tmp .= $txt[$i] ^ $encrypt_key[$ctr++]; |
| 58 | public function __destruct() { |
| 59 | $this -> crypt_key = null; |
| 64 | $sc = new SysCrypt('phpwms'); |
| 66 | print($sc -> php_encrypt($text)); |
| 68 | print($sc -> php_decrypt($sc -> php_encrypt($text))); |
/*=========================================================== = 版权协议: = GPL (The GNU GENERAL PUBLIC LICENSE Version 2, June 1991) =------------------------------------------------------------ = 文件名称:cls.sys_crypt.php = 摘 要:php加密解密处理类 = 版 本:1.0 = 参 考:Discuz论坛的passport相关函数 =------------------------------------------------------------ = Script Written By PHPWMS项目组 = 最后更新:xinge = 最后日期:2007-12-09 ============================================================*/ class SysCrypt { private $crypt_key; // 构造函数 public function __construct($crypt_key) { $this -> crypt_key = $crypt_key; } public function php_encrypt($txt) { srand((double)microtime() * 1000000); $encrypt_key = md5(rand(0,32000)); $ctr = 0; $tmp = ''; for($i = 0;$i<strlen($txt);$i++) { $ctr = $ctr == strlen($encrypt_key) ? 0 : $ctr; $tmp .= $encrypt_key[$ctr].($txt[$i]^$encrypt_key[$ctr++]); } return base64_encode(self::__key($tmp,$this -> crypt_key)); } public function php_decrypt($txt) { $txt = self::__key(base64_decode($txt),$this -> crypt_key); $tmp = ''; for($i = 0;$i < strlen($txt); $i++) { $md5 = $txt[$i]; $tmp .= $txt[++$i] ^ $md5; } return $tmp; } private function __key($txt,$encrypt_key) { $encrypt_key = md5($encrypt_key); $ctr = 0; $tmp = ''; for($i = 0; $i < strlen($txt); $i++) { $ctr = $ctr == strlen($encrypt_key) ? 0 : $ctr; $tmp .= $txt[$i] ^ $encrypt_key[$ctr++]; } return $tmp; } public function __destruct() { $this -> crypt_key = null; } } $sc = new SysCrypt('phpwms'); $text = '110'; print($sc -> php_encrypt($text)); print('<br>'); print($sc -> php_decrypt($sc -> php_encrypt($text))); ?>