Heim > Artikel > Backend-Entwicklung > Was tun, wenn PHP Base64 verstümmelt ist?
php base64 verstümmelte Zeichen sind darauf zurückzuführen, dass bei der Übergabe in der GET-Form das „+“-Zeichen durch ein Leerzeichen ersetzt wird, was zu verstümmelten Zeichen führt.
Lösung zum Dekodieren verstümmelter Zeichen nach der PHP-Base64-Kodierung
In diesem Artikel wird hauptsächlich die Dekodierung nach der PHP-Base64-Kodierung vorgestellt. Die Lösung Zu verstümmelten Codes gehört, dass die Base64-Kodierung einige Sonderzeichen enthält. Freunde in Not können sich auf
Empfehlenswert: „PHP-Tutorial“ beziehen.
Ich habe eins gefunden Problem, als ich etwas mit PHP erstellt habe. Es kann einfach auf das Problem verstümmelter Zeichen zurückgeführt werden, aber dieses Problem wird nicht durch die Funktion selbst verursacht. Finden wir heraus, wer der Täter ist.
Verdächtige: base64_encode und base64_decode
Verbrechen: Ich habe eine Sprung- und Eingabeaufforderungsfunktion geschrieben, die nach Erhalt der Eingabeaufforderungsinformationen zur angegebenen Seite springt, aber die chinesischen Schriftzeichen sind während der Sprungaufforderung verstümmelt.
Der Sprungvorlagencode lautet wie folgt:
Der Code lautet wie folgt:
<!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>
Die PHP-Umleitungsfunktion ist wie folgt definiert:
Der Code lautet wie folgt:
/* 提醒后跳转 */ 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; }
Wenn Sie eine Funktion in PHP wie folgt aufrufen:
Der Code lautet wie folgt:
$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'); }
Sie werden sehen, dass die chinesischen Zeichen für „Modifikation „Erfolgreich“ oder „Änderung fehlgeschlagen“ sind verstümmelt.
Warum?
Manchmal wird es nach der Verschlüsselung mit base64_encode in Form von GET an andere Seiten übertragen, und beim Entschlüsseln mit base64_decode erscheinen verstümmelte Zeichen.
Als ich auf dieses Problem stieß, fragte ich mich, warum einige korrekt entschlüsselt werden konnten, andere jedoch verstümmelt waren.
Nachdem ich später nachgesehen hatte, stellte ich fest, dass bei der Übergabe in GET einige chinesische Zeichen vorhanden waren Formular wird das +-Zeichen durch ein Leerzeichen ersetzt.
Um zu verhindern, dass verstümmelte Zeichen angezeigt werden, habe ich eine einstufige Ersetzung vorgenommen und sie dann entschlüsselt. Tatsächlich besteht das Problem der verstümmelten Zeichen nicht mehr.
Jetzt ist das Problem sehr groß Ganz einfach, schreiben Sie einfach mehr. Nur ein Schritt reicht aus
Der Code lautet wie folgt:
$str = base64_decode(str_replace(" ","+",$_GET['str']));
Es stellt sich heraus, dass der Artikel am Anfang den falschen Verdächtigen identifiziert und diese beiden Funktionen fälschlicherweise beschuldigt hat. . .
Das obige ist der detaillierte Inhalt vonWas tun, wenn PHP Base64 verstümmelt ist?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!