在用PHP做東西的時候發現了一個問題,可以簡單的歸結為亂碼的問題,但是這個問題不是函數本身造成的。來看看罪魁禍首是誰。
嫌疑人:base64_encode 和 base64_decode
罪行:我寫了一個跳轉和提示函數,接收提示資訊後跳轉到指定的頁面,但是跳轉提示時漢字亂碼。
跳轉模版代碼如下:
複製代碼 代碼如下:
跳轉提示
<?php if( $_GET['success'] ){?>
:) 恭喜!
<?php echo base64_decode($_GET['message']); ?>
<?php }else{?>
:( 出錯了!
<?php echo base64_decode($_GET['message']); ?>
<?php }?>
系統將在 <?php echo $_GET['time']; ?> 後跳轉,可直接 ">點此跳轉
PHP redirect函數定義如下:
複製代碼 代碼如下:
/* 提醒後跳轉 */
function _alert( $success=true, $message='success', $time='3', $url='/'){
header('Location:/include/redirect.php?success='.$success.'&message='.base64_encode($message).'&time='.$time.'&url='.base64_encode($url));
exit;
}
假如在PHP中這樣調用函數的話:
複製代碼 代碼如下:
$query = "update content set bid='$clean[bid]',title='$clean[title]',content='$clean[content]',path='$clean[path]' where id=".$clean['id'];
if( mysql_query($query) ){
_alert(1,'修改成功',3,'/admin/manage.php');
}else{
_alert(false,'修改失敗'.mysql_error(),5,'/admin/manage.php');
}
你就會看到,“修改成功”或者是“修改失敗”這幾個漢字亂碼了。
為什嗎?
有時候用base64_encode加密後,以GET的形式傳到其他頁面,用base64_decode解密的時候,出現亂碼。
遇到這個問題的時候,我就納悶了,為什麼有一些能正確解密,但是有一些卻出現亂碼呢?
後來經過檢查,發現有一些中文字元,用GET形式傳過來的時候,+號會被替換成空格。
為了防止出現亂碼的情況,我做了一步替換,然後再解密,果然,亂碼的問題,不複存在了!
現在問題已經很簡單了,只要多寫一步就好了
複製代碼 代碼如下:
$str = base64_decode(str_replace(" ","+",$_GET['str']));
原來,文章一開始定錯了嫌疑人了,冤枉了那兩個函數了。。。
還可以參考這篇文章:PHP安全的URL字串base64編碼和解碼
http://www.bkjia.com/PHPjc/825406.htmlwww.bkjia.comtruehttp://www.bkjia.com/PHPjc/825406.htmlTechArticle在用PHP做東西的時候發現了一個問題,可以簡單的歸結為亂碼的問題,但是這個問題不是函數本身造成的。來看看罪魁禍首是誰。 嫌疑人:...