0

タグ$_POST['nimage']の src 値として直接エコーする場合、 $_POST フィールドに base64 でエンコードされた文字列があります。ブラウザで画像が正常に表示されます。imgecho "<img src='".$_POST['nimage']."'>";

base64_decode文字列をサーバー上のローカルのファイルに書き込むと、作成されたファイルをブラウザーで表示しようとするとエラーが発生するため、明らかに手順がありません。

「画像 'xxxx://myserversomewhere.com/images/img1.jpg' はエラーが含まれているため表示できません」

私のデコードとファイルの書き込みは次のとおりです。

$file = base64_decode($_POST['nimage']);
file_put_contents('images/'. $_POST['imgname'], $file);

その結果images/img1.jpg、ローカルサーバーになります。ここでのデコードで何が間違っていますか? base64 出力は URL エンコードされていないように見えますが、base64_decode() の前に最初に urldecode() を試してみましたが、安全な方法で同じ結果が得られました。

base64 エンコードの最初の数行は次のとおりです。



4

1 に答える 1

0

デコードしているデータには、データ URI ヘッダーが添付されています。

...

ヘッダーは、ファイルの種類とエンコードを識別するためにブラウザーによって使用されますが、エンコードされたデータの一部ではありません。

データからヘッダー ( data:image/jpeg;base64,) を取り除き、ファイルに書き込む前に残りを base64 でデコードします。

$b64 = '...';
$dat = explode(',' $b64);

// element 1 of array from explode() contains B64-encoded data
if (($fileData = base64_decode($dat[1])) === false) { 
   exit('Base64 decoding error.');
}
file_put_contents($someFileName, $fileData);

base64_decode()注意: forへの呼び出しの戻り値を確認し、false何らかのメッセージで中止してください。デコード プロセスの問題をトラップします (ヘッダーを削除しないなど)。

于 2015-06-08T03:25:33.553 に答える