解码因为gfw(伟大的防火墙)在我国,我必须在http传输(https更好,但它的第二选择)内编码内容。由php编码并由js
我的方法是用php base64编码并通过js解码,然后在iframe中显示。但FF中有一些问题。
有什么更好的方法来显示base64编码的字符串在浏览器中,或另一种方式来编码/解码?
解码因为gfw(伟大的防火墙)在我国,我必须在http传输(https更好,但它的第二选择)内编码内容。由php编码并由js
我的方法是用php base64编码并通过js解码,然后在iframe中显示。但FF中有一些问题。
有什么更好的方法来显示base64编码的字符串在浏览器中,或另一种方式来编码/解码?
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);
}
我真的很希望这些函数被疯狂地错误标记,因为MD5不加密,并且是不可逆的,因为它是一个哈希函数。 – You 2010-07-07 22:13:27
真的,他们是一个哈希函数...我使用它们来编码我的值,当然传递...然后做一个base64编码。当然也是相反的解密它们。为了模糊数据。 – 2010-07-08 14:01:16
你可以只设置页面的正文的文字属性...
只要编码的字符串,在JS的生产是整个身体有效的HTML,它应该工作正常,然后你不必对iframe或其他东西做任何混乱的事情。
是的,这是一种方式,我认为它会起作用 – limboy 2010-07-07 22:51:34
你能展示你使用的代码吗? – 2010-07-07 22:17:45
另外,我并不完全确定这里的基本前提:如果防火墙不能检测和解码base64编码的内容,那将是相当糟糕的 - 而且,可悲的是,它不是我听到:)你究竟在哪里转移到哪里?什么时候事情会被过滤? – 2010-07-07 22:19:20
gfw是中间的人,它会搜索你转移的内容使用http。所以我想在服务器中编码,并在浏览器中解码。 为了节省时间,我终于用https解决了这个问题,谢谢你的评论 – limboy 2010-07-07 22:49:19