• 一组PHP可逆加密解密算法


    对于大部分密码加密,我们可以采用md5、sha1等方法。可以有效防止数据泄露,但是这些方法仅适用于无需还原的数据加密。

    对于需要还原的信息,则需要采用可逆的加密解密算法。

    下面一组PHP函数是实现此加密解密的方法:

    加密算法如下:

    function encrypt($data, $key)
    {
    	$key	=	md5($key);
        $x		=	0;
        $len	=	strlen($data);
        $l		=	strlen($key);
        for ($i = 0; $i < $len; $i++)
        {
            if ($x == $l) 
            {
            	$x = 0;
            }
            $char .= $key{$x};
            $x++;
        }
        for ($i = 0; $i < $len; $i++)
        {
            $str .= chr(ord($data{$i}) + (ord($char{$i})) % 256);
        }
        return base64_encode($str);
    }

    解密算法如下:
    function decrypt($data, $key)
    {
    	$key = md5($key);
        $x = 0;
        $data = base64_decode($data);
        $len = strlen($data);
        $l = strlen($key);
        for ($i = 0; $i < $len; $i++)
        {
            if ($x == $l) 
            {
            	$x = 0;
            }
            $char .= substr($key, $x, 1);
            $x++;
        }
        for ($i = 0; $i < $len; $i++)
        {
            if (ord(substr($data, $i, 1)) < ord(substr($char, $i, 1)))
            {
                $str .= chr((ord(substr($data, $i, 1)) + 256) - ord(substr($char, $i, 1)));
            }
            else
            {
                $str .= chr(ord(substr($data, $i, 1)) - ord(substr($char, $i, 1)));
            }
        }
        return $str;
    }

    上述加密解密的过程均需要用到一个加密密钥(即参数$key)。

    $data = 'PHP加密解密算法';		// 被加密信息
    $key = '123';					// 密钥
    $encrypt = encrypt($data, $key);
    $decrypt = decrypt($encrypt, $key);
    echo $encrypt, "
    ", $decrypt;


    上述将输出类似如下结果:

    gniCSOzZG+HnS9zcFea7SefNGhXF
    PHP加密解密算法

    从上述结果可以看出,这是一组可逆的加密解密算法,可以用于部分需要还原的数据加密。





  • 相关阅读:
    软件构造 第七章第三节 断言和防御性编程
    软件构造 第七章第二节 错误与异常处理
    软件构造 第七章第一节 健壮性和正确性的区别
    软件构造 第六章第三节 面向可维护的构造技术
    软件构造 第六章第二节 可维护的设计模式
    欧拉函数代码实现及扩展--快速矩阵幂
    编译原理
    算法设计与分析总结
    人工智能简答总结
    感想
  • 原文地址:https://www.cnblogs.com/yingjie13/p/3527782.html
Copyright © 2020-2023  润新知