php加解密

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;
    }

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值