在用PHP做東西的時候發現了一個問題,可以簡單的歸結為亂碼的問題,但是這個問題不是函數本身造成的。來看看罪魁禍首是誰。
嫌疑人:base64_encode 和 base64_decode
罪行:我寫了一個跳轉和提示函數,接收提示資訊後跳轉到指定的頁面,但是跳轉提示時漢字亂碼。
跳轉模版代碼如下:
複製代碼 代碼如下:
<!DOCTYPE html><html><head><meta charset="utf-8"><meta name="author" content="王健 wj@yurendu.com" />
<title>跳轉提示</title>
<style type="text/css">
*{ padding: 0; margin: 0; }
body{ background: #fff; font-family: '微軟雅黑'; color: #333; font-size: 16px; text-align:center; }
.system-message{ width:600px; margin:150px auto 0 auto; background:#f8f8f8; border:1px solid #ccc;-webkit-border-radius: 8px;-moz-border-radius: 8px;border-radius: 8px;-webkit-box-shadow: #666 0px 0px 10px;-moz-box-shadow: #666 0px 0px 10px;box-shadow: #666 0px 0px 10px;}
.system-message h1{ font-size:30px; font-weight:normal; height:100px; line-height:100px; color:#c60;}
.system-message .jump{ padding: 40px 0;}
.system-message .jump a{ color: #333;}
.system-message .success,.system-message .error{ height:60px; line-height:70px; font-size: 18px; color:#900;}
.system-message .detail{ font-size: 12px; line-height: 20px; margin-top: 12px; display:none}
</style>
</head>
<body>
<div class="system-message">
<?php if( $_GET['success'] ){?>
<h1>:) 恭喜!</h1>
<p class="success"><?php echo base64_decode($_GET['message']); ?></p>
<?php }else{?>
<h1>:( 出錯了!</h1>
<p class="error"><?php echo base64_decode($_GET['message']); ?></p>
<?php }?>
<p class="detail"></p>
<p class="jump">系統將在 <b id="wait"><?php echo $_GET['time']; ?></b> 後跳轉,可直接 <a id="href" href="<?php echo base64_decode($_GET['url']); ?>">點此跳轉</a></p>
</div>
<script type="text/javascript">
(function(){
var wait = document.getElementById('wait'),href = document.getElementById('href').href;
var interval = setInterval(function(){
var time = --wait.innerHTML;
if(time <= 0) {
location.href = href;
clearInterval(interval);
};
}, 1000);
})();
</script>
</body>
</html>
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編碼和解碼