プロジェクト

全般

プロフィール

Bug(バグ) #2476

完了

PHP 5.3.4 以降の場合に画像付きメール投稿が失敗する

Minoru Takai さんが約13年前に追加. 約9年前に更新.

ステータス:
Fixed(完了)
優先度:
High(高め)
担当者:
対象バージョン:
開始日:
2011-10-06
期日:
進捗率:

100%

予定工数:
3.6 で発生するか:
Unknown (未調査)
3.8 で発生するか:
Unknown (未調査)

説明

概要

この問題は #2261 の対応中に発見されました。この問題 http://redmine.openpne.jp/issues/2261#note-5 については本チケットで扱います。

PHPのバージョンが新しいとき(この意味は以下を参照)、メール投稿において画像を添付すると(添付画像の個数は任意)添付画像が受け付けられない。

PHPのバージョンと base64_decode() の挙動/RFC3548

最後に改行が余分に入ったbase64エンコードデータをstrict modeで処理した場合の挙動をPHP 5.2.17, 5.3.0〜5.3.6の各バージョンで調べたところ、5.3.4 以降で FALSE が返るようになっていました。

PHP 5.3.4 (see http://php.net/ChangeLog-5.php#5.3.4 ) において、base64_decode() 関連で修正があったようです。(Base64について定義しているRFC3548に厳格に従うよう修正されたということでしょうか)
http://svn.php.net/viewvc/php/php-src/trunk/ext/standard/base64.c?r1=305779&r2=305778&pathrev=305779
http://www.ietf.org/rfc/rfc3548.txt

原因

最新のPHPにおいて、base64_decode() を strictモード(第2引数をtrue)で使うとmultipartから取得した画像データ(base64-encoded text)の末尾に改行が余分に含まれていると FALSE を返す。添付画像は application/x-empty とみなされ画像とはみなされず無視される。

修正方法

base64_decode($content, true); の箇所を base64_decode(rtrim($content), true); に変更する。


関連するチケット 3 (1件未完了2件完了)

関連している OpenPNE 3 - Bug(バグ) #2261: メール投稿で画像を1つだけ送信すると画像として扱われないことがあるRejected(差し戻し)2011-07-05

操作
関連している OpenPNE 3 - Backport(バックポート) #2477: PHP 5.3.4 以降の場合に画像付きメール投稿が失敗するFixed(完了)Minoru Takai2011-10-06

操作
関連している OpenPNE 3 - Backport(バックポート) #2613: PHP 5.3.4 以降の場合に画像付きメール投稿が失敗するFixed(完了)Minoru Takai2011-10-06

操作

他の形式にエクスポート: Atom PDF