解碼因爲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