php加解密

本文介绍了一种使用PHP实现的字符串加密与解密的方法。该方法通过自定义的passport_encrypt和passport_decrypt函数来完成加密和解密过程,并利用了base64编码、随机数生成及MD5哈希等技术手段确保数据的安全性。
public function bbbAction()
    {
        $str='cab';
        echo "加密前:".$str;
        $str=self::passport_encrypt($str);
        echo "加密后:".$str;
        $str=self::passport_decrypt($str);
        echo "解密后:".$str;
        $str='ccc1asddddddddddddddddddddddddddddddddddddddddddddd';
        echo "加密前:".$str;
        $str=self::passport_encrypt($str);
        echo "加密后:".$str;
        $str=self::passport_decrypt($str);
        echo "解密后:".$str;
    }
    //--------------------------------------------------------------------------
    /*
     * 对字符串进行解密处理
     * @param string 需要解密的密文
     */
    public static function passport_decrypt($str)
    {
        $str = self::passport_key(base64_decode($str), \toprank\server\getConst::getConst('MD5KEY'));
        $tmp = "";

        if ((strlen($str) % 2) != 0) {
            return $str;
        }

        for ($i = 0; $i < strlen($str); $i++) {
            $md5 = $str[$i];
            $tmp .= $str[++$i] ^ $md5;
        }

        return $tmp;
    }
    //--------------------------------------------------------------------------
    /*
     * 对字符串进行加密处理
     * @param string 需要加密的内容
     */
    public static function passport_encrypt($str)
    {
        srand((double) microtime() * 1122345);
        $encrypt_key = md5(rand(0, 32000));
        $ctr         = 0;
        $tmp         = "";

        for ($i = 0; $i < strlen($str); $i++) {
            $ctr = ($ctr == strlen($encrypt_key) ? 0 : $ctr);
            $tmp .= $encrypt_key[$ctr] . ($str[$i] ^ $encrypt_key[$ctr++]);
        }

        return base64_encode(self::passport_key($tmp, \toprank\server\getConst::getConst('MD5KEY')));
    }

    /*
     * 辅助函数
     */
    public static function passport_key($str, $encrypt_key)
    {
        $encrypt_key = md5($encrypt_key);
        $ctr         = 0;
        $tmp         = "";

        for ($i = 0; $i < strlen($str); $i++) {
            $ctr = ($ctr == strlen($encrypt_key) ? 0 : $ctr);
            $tmp .= $str[$i] ^ $encrypt_key[$ctr++];
        }

        return $tmp;
    }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值