由php编码并由js解码

时间:2010-07-07 22:06:07

标签: php javascript encode

因为我们国家的gfw(很棒的防火墙),我必须在http传输中编码内容(https更好,但它是第二选择)。

我的方式是使用php的base64编码和js解码,然后在iframe中显示。但是在FF中存在一些问题。

有没有更好的方法在浏览器中显示base64编码的字符串,或其他方式进行编码/解码?

2 个答案:

答案 0 :(得分:0)

Try Something this:

    function get_rnd_iv($iv_len)
    {
        $iv = '';
        while ($iv_len-- > 0) {
            $iv .= chr(mt_rand() & 0xff);
        }
        return $iv;
    }

    function md5_encrypt($string_value, $salt_key, $iv_len = 16)
    {
        $string_value .= "\x13";
        $n = strlen($string_value);
        if ($n % 16) $string_value .= str_repeat("\0", 16 - ($n % 16));
        $i = 0;
        $enc_text = get_rnd_iv($iv_len);
        $iv = substr($salt_key ^ $enc_text, 0, 512);
        while ($i < $n) {
            $block = substr($string_value, $i, 8) ^ pack('H*', md5($iv));
            $enc_text .= $block;
            $iv = substr($block . $iv, 0, 512) ^ $salt_key;
            $i += 16;
        }
        return urlencode(base64_encode($enc_text));
    }

    function md5_decrypt($enc_text, $salt_key, $iv_len = 16)
    {
        $enc_text = urldecode(base64_decode($enc_text));
        $n = strlen($enc_text);
        $i = $iv_len;
        $string_value = '';
        $iv = substr($salt_key ^ substr($enc_text, 0, $iv_len), 0, 512);
        while ($i < $n) {
            $block = substr($enc_text, $i, 8);
            $string_value .= $block ^ pack('H*', md5($iv));
            $iv = substr($block . $iv, 0, 512) ^ $salt_key;
            $i += 16;
        }
        return preg_replace('/\\x13\\x00*$/', '', $string_value);
    }

答案 1 :(得分:0)

您可以设置页面正文的innerHTML属性...

只要JS生成的编码字符串是整个身体的有效HTML,它应该可以正常工作,然后你就不必对iframe或其他任何事情做任何麻烦。