web-dev-qa-db-ja.com

WordPress 4.0でフロントエンド経由で特定の.Zipファイルタイプをアップロードできない

フロントエンドから選択した数種類のファイルをアップロードすることを許可します。 .zip、.mp4、.jpeg、および.pdf今までのところ、これらすべての種類のファイルには、アップロード先の投稿に問題はありませんでした。ただし、WordPress 4.0にアップグレードした後は、フロントエンドから特定の.Zipファイルタイプをアップロードすることはできませんでしたが、メディアアップロードインターフェイスを使用してバックエンドからうまくアップロードできました。他のファイルタイプ .mp4および.pdfファイルはまだ問題なく添付されていることに注意してください。

添付機能を実行するコード全体を以下に示します。

if ( isset( $_POST['upload_attachments'] ) && $_SERVER['REQUEST_METHOD'] === 'POST' && wp_verify_nonce($_POST['secure_upload'], 'upload_attachments_nonce')) {

    //checking if upload is empty
    //checking if universal filesize is valid

    if ($_FILES) { //loop through multiple files.         
        $files = $_FILES['upload'];
        foreach ($files['name'] as $key => $value) {
            if ($files['name'][$key]) {
                $file = array(
                    'name'     => $files['name'][$key],
                    'type'     => $files['type'][$key],
                    'tmp_name' => $files['tmp_name'][$key],
                    'error'    => $files['error'][$key],
                    'size'     => $files['size'][$key]
                );

                $uploaded_file_type = $files['type'][$key];
                $allowed_file_types = array('image/jpg', 'image/jpeg', 'image/png', 'application/pdf', 'application/Zip', 'video/mp4');
                $uploaded_file_size = $files['size'][$key];
                $size_in_kb = $uploaded_file_size / 1024;
                $file_size_limit = 10000; // Your Filesize in KB


                if(in_array($uploaded_file_type,  $allowed_file_types)) { 
                   if( $size_in_kb > $file_size_limit ) {
                   $upload_error .= 'Image files must be smaller than '.$file_size_limit.'KB';
                   return;
                   } else {
                   $_FILES = array("upload" => $file);
                   foreach ($_FILES as $file => $array) {
                   $newupload = insert_attachment($file,$post_id);
                   //return; this loop neds to run multiple times so no return here
                 }      
                 }
                 } else { $upload_error .= 'Invalid File type';
                         return;
                        }                                                              

                }
            }
        }                  

    header ('Location: ' . $_SERVER['REQUEST_URI']);//Post, redirect and get
    exit();
    }//end of nonce check 

ヘルパー関数 goldenapplesによる/ insert_attachment

function insert_attachment($file_handler,$post_id,$setthumb='false') {

    // check to make sure its a successful upload
    if ($_FILES[$file_handler]['error'] !== UPLOAD_ERR_OK) __return_false();

    require_once(ABSPATH . "wp-admin" . '/includes/image.php');
    require_once(ABSPATH . "wp-admin" . '/includes/file.php');
    require_once(ABSPATH . "wp-admin" . '/includes/media.php');

    $attach_id = media_handle_upload( $file_handler, $post_id );

    //if ($setthumb) update_post_meta($post_id,'_thumbnail_id',$attach_id);
    return $attach_id;
}

フォームHTML

<form method="post" id="frontend-attachment-upload-form" action="" enctype="multipart/form-data" >
<input type="file" multiple="true" name="upload[]">   

<?php wp_nonce_field('upload_attachments_nonce','secure_upload'); ?>
<input type="submit" id="upload_attachments_button" name="upload_attachments" value="UPLOAD">
<form>

.Zipファイルはまったくアップロードされていません。そうでなければ、たとえアタッチされていなくても、メディアライブラリで見つけることができます。フロントエンドに.Zipファイルをアップロードしようとすると、単に無効なファイルの種類のエラーが返されます。ご覧のとおり、この行はすべてのファイルタイプを明確に定義しています。

$allowed_file_types = array('image/jpg', 'image/jpeg', 'image/png', 'application/pdf', 'application/Zip', 'video/mp4');

それでは、他のすべてのファイルタイプの.mp4、.pdf、.jpegが正しく添付され、.Zipが正しく添付されないのはどうしてですか。論理的には、ループに間違いがあった場合、ファイルタイプはまったくアップロードされません。 .zipファイルが数日前までうまくアップロードされていたことも事実です。私は何が起こっているのかわかりません。少し手助けをお願いします。


念のため、許可されているファイルタイプを確認したところ、.Zipファイルタイプが許可されていると表示されていました。それで、wordpressがimage.phpfile.phpあるいはmedia.phpに何らかのフロントエンドでアップロードされる特定のファイルタイプをブロックするような変更を行った可能性はありますか?

<?php $allowed_mimes = get_allowed_mime_types();
        echo '<pre>';
        print_r($allowed_mimes);
        echo '</pre>';
        ?>

更新:この問題は解決されました。親切に受け入れられた答えを見てください。

2
gurung

*私はこれをアップデートとして書くつもりだと思いましたが、質問アップデートで誰かが解決策を飛ばすかもしれないので解決策を答えとして提供する方が良いと思いました。

それについては、私のコードやループに間違いはありません。これもサーバーの誤設定ではありません。デバッグの一環として、アップロードされたファイルタイプをエコーバックしていましたが、.Zipファイルをアップロードすると、application/x-Zip-compressedではなくapplication/Zipとして返されることに気付きました。そのため、コードを少し変更するだけでうまくいきました。

$allowed_file_types = array('application/x-Zip-compressed', 'other file types......');

.rarファイルがapplication/x-rar-compressedでなければならないことにも注意するために、上記は上手く動きました。 関連コーデックスページ に記載されていることを願います。私はまだこれがワードプレス4.0に付属していたものであると確信しています。 @ialocin、@ aifrim、その他の方々に感謝します。

0
gurung

あなたはWordPressがその設定で持っている許可されたMIMEタイプを更新する必要があります。

Zip/rarファイルの場合:

function my_modify_mimes( $mimes ) {

    $mimes['Zip'] = 'application/Zip';
    $mimes['rar'] = 'application/x-rar-compressed';

    return $mimes;
}

add_filter( 'upload_mimes', 'my_modify_mimes' );

また、フロントエンドからアップロードしている場合は、ロール/機能によって特定のMIMEタイプにアクセスできるユーザーをフィルター処理する必要があります。

RAR/ZIPもこのMIMEタイプで識別されます。 application/octet-stream エラーが発生した場合。

0
aifrim