画像がアップロードできない

症状

WordPressの管理画面から画像を複数アップロードするときにエラーが起きる。
画像アップロードには、
 1.ブラウザーアップローダー
 2.マルチファイルアップローダー
の2つが用意されていて、このうち「2.マルチファイルアップローダー」で画像をアップロードしようとすると必ずエラーになる。

複数ではなく、マルチファイルアップローダーを使って画像をあげようとすると、単体でもエラーになる。

管理画面上表示されるエラーは、
「 アップロード中にエラーが発生しました。後ほど再度お試しください。
というエラー。

あと、
こんな感じのエラー。
画像:

テキスト:

post_type ) wp_die( __( 'Unknown post type.' ) ); if ( ! current_user_can( 'edit_post', $id ) ) wp_die( __( 'Sorry, you are not allowed to edit this item.' ) ); switch ( $_REQUEST['fetch'] ) { case 3 : if ( $thumb_url = wp_get_attachment_image_src( $id, 'thumbnail', true ) ) echo ''; echo '' . _x( 'Edit', 'media item' ) . ''; // Title shouldn't ever be empty, but use filename just in case. $file = get_attached_file( $post->ID ); $title = $post->post_title ? $post->post_title : wp_basename( $file ); echo '
' . esc_html( wp_html_excerpt( $title, 60, '…' ) ) . '
'; break; case 2 : add_filter('attachment_fields_to_edit', 'media_single_attachment_fields_to_edit', 10, 2); echo get_media_item($id, array( 'send' => false, 'delete' => true )); break; default: add_filter('attachment_fields_to_edit', 'media_post_single_attachment_fields_to_edit', 10, 2); echo get_media_item($id); break; } exit; } check_admin_referer('media-form'); $post_id = 0; if ( isset( $_REQUEST['post_id'] ) ) { $post_id = absint( $_REQUEST['post_id'] ); if ( ! get_post( $post_id ) || ! current_user_can( 'edit_post', $post_id ) ) $post_id = 0; } $id = media_handle_upload( 'async-upload', $post_id ); if ( is_wp_error($id) ) { echo '
' . __('Dismiss') . '' . sprintf(__('“%s” has failed to upload.'), esc_html($_FILES['async-upload']['name']) ) . '
' . esc_html($id->get_error_message()) . '
'; exit; } if ( $_REQUEST['short'] ) { // Short form response - attachment ID only. echo $id; } else { // Long form response - big chunk o html. $type = $_REQUEST['type']; /** * Filters the returned ID of an uploaded attachment. * * The dynamic portion of the hook name, `$type`, refers to the attachment type, * such as 'image', 'audio', 'video', 'file', etc. * * @since 2.5.0 * * @param int $id Uploaded attachment ID. */ echo apply_filters( "async_upload_{$type}", $id ); }

しかも、これでPHPのエラーログには出力されないと来た。

どうやって探すか。
とりあえず、ぐぐるか。
そして、めんどくさいけど、デバッグしていくか。

同じ症状の人を探してみる

「WordPress 画像アップロードできない」
「WordPress アップロード中にエラーが発生しました。後ほど再度お試しください。」

とかでぐぐってみる。
が、でてくるのは大抵、
1.パーミッションかグループの問題。
   i) wp-admin/uploads あたりのグループユーザがWordPressを動かしているユーザと違うパターン
          → chgrp -R #変更したいグループ名 #変更したいファイルパス
→ chown -R #変更したいユーザ名 #変更したいファイルパス
          どちらかで解決
ii) wp-admin/uploadsのパーミッションが、755。
         → chmod -R 0755 #変更したいファイルパス
          これで解決

2.アップロードする先の容量の問題
   →サーバの容量増やさなきゃだめ

3.どこかのファイルが破損しているため
  →破損場所探す or WordPressインストールし直す

4.PHPがセーフモードで動いていて、どこかのFunctionが使えなくなっているかも?
  →セーフモードにしなくすればいい

ぐらいしか出てこない。

とりあえず、1に関しては問題ない
(ユーザもグループもパーミッションも必要な設定している。ブラウザアップロードできる時点で大丈夫と思うし。)
2も問題ない(容量いっぱいあった)。
3はアップロードそのものがエラーになるだろうから、これもブラウザアップロードで来ている時点で(ry
あと、クリーンインストールはめんどくさい。

4はphpinfo()で見れるけど、phpinfo()するのめんどくさい。
サーバにはいって、
php -a
でphpをインタラクションモードで立ち上げて、
echo ini_get(‘safe_mode’);
してみるが、なにも表示されないのでFalse(=セーフモードではない)

とりあえず、デバッグしてみるか。
上の変なエラーでているあたり。

デバッグ

上でエラーになっているのは、
wp-admin/async-upload.php
だった。

エラー内容Grepしてみた結果、ここだった。
デバッグしてみるが、大丈夫っぽい。
つかAsyncのせいか、Debugし辛い。。

ここでふと思う。
待てよ。

ファイル名で検索してみればいいんでない?
ということで、検索。

すると、下記の記事がヒット。
画像がアップロードできなくなった?

まさかねー、と思いつつ、.htaccessを覗いてみると。。



AddHandler application/x-httpd-phpcgi .php


。。。いやがった。
しかもこれ、wp-admin/配下にこれだけ置いてあった。
いつ置いたよ俺Σ

もうこれじゃね?
うん、これでいいよね?
てかこれにして?

とか思いつつ、ぜんぶコメントアウト。

アップロード試してみる。

はい!

きた!

アップロードできるようになりました。

くそ、こんなことで時間使っちゃったのか。
でも解決できたからいいや。

ってことで、無事解決。

解決策

.htaccess
の、下記記述削除。



AddHandler application/x-httpd-phpcgi .php


よかったー!

[amazonjs asin=”4774187062″ locale=”JP” title=”エンジニアのためのWordPress開発入門 (Engineer’s Library)”]

[amazonjs asin=”4774150363″ locale=”JP” title=”サーバ構築の実際がわかる Apache実践運用/管理 (Software Design plus)”]

投稿者 iyken

「【WordPress】画像アップロード中にエラー」に2件のコメントがあります
  1. ありがとうございます!
    ほかのアップロードできない系でググったら
    wp-admin/配下
    ここに
    .htaccess
    に上記記述をして置けってのがありました。
    情報がいろいろ交差しますね。

    1. >うみのるり さん
      すみません返信が遅くなってしまいました。。

      なるほど、そのへんの情報をみて設定してしまったんですね。。。
      ありがとうございます!

コメントを残す

メールアドレスが公開されることはありません。 が付いている欄は必須項目です