web-dev-qa-db-ja.com

を使用してWordpressのページに画像をアップロードする PHP

SEさん、こんにちは。 :)

さて、これは少し先の話ですが、私はPHPアップロードスクリプトを含むHTMLフォームをWordpressページ内で動作させることを試みています。プラグインが使えません。これは、顧客がHTMLフォームを介して画像をアップロードできるデザインチームのようなWebページであることが想定されています(ログインとスタッフが必要になりますが、後で説明します)。

私は子供のテーマを手に入れ、 "upload"というページを作成し、 "page-upload.php"ファイルを編集しています。

page-upload.phpの私のフォーム

        <form action="<?php bloginfo('template_url'); ?>/upload.php" method="post" enctype="multipart/form-data">
           <input type="file" name="file" />
            <input type="submit" name="submit" value="Upload" />
        </form>

form action = "upload.php"でファイルが正しく見つかりませんでした。

<?php bloginfo( 'template_url');?>/upload.php "

これはファイルを見つけることができますが、画像をアップロードする代わりに、PHPからのすべてのエコーをエコーするだけです。

W3Schools PHPファイルアップロードの例を使って始めましたが、期待したほど単純ではありませんでした^ _ ^

http://www.w3schools.com/php/php_file_upload.asp

<?php
$target_dir = "uploads/";
$target_file = $target_dir . basename($_FILES["fileToUpload"]["name"]);
$uploadOk = 1;
$imageFileType = pathinfo($target_file,PATHINFO_EXTENSION);
// Check if image file is a actual image or fake image
if(isset($_POST["submit"])) {
    $check = getimagesize($_FILES["fileToUpload"]["tmp_name"]);
    if($check !== false) {
        echo "File is an image - " . $check["mime"] . ".";
        $uploadOk = 1;
    } else {
        echo "File is not an image.";
        $uploadOk = 0;
    }
}
// Check if file already exists
if (file_exists($target_file)) {
    echo "Sorry, file already exists.";
    $uploadOk = 0;
}
// Check file size
if ($_FILES["fileToUpload"]["size"] > 500000) {
    echo "Sorry, your file is too large.";
    $uploadOk = 0;
}
// Allow certain file formats
if($imageFileType != "jpg" && $imageFileType != "png" && $imageFileType != "jpeg"
&& $imageFileType != "gif" ) {
    echo "Sorry, only JPG, JPEG, PNG & GIF files are allowed.";
    $uploadOk = 0;
}
// Check if $uploadOk is set to 0 by an error
if ($uploadOk == 0) {
    echo "Sorry, your file was not uploaded.";
// if everything is ok, try to upload file
} else {
    if (move_uploaded_file($_FILES["fileToUpload"]["tmp_name"], $target_file)) {
    echo "The file ". basename( $_FILES["fileToUpload"]["name"]). " has been uploaded.";
} else {
    echo "Sorry, there was an error uploading your file.";
    }
}
    ?>

それでこれはWP内でPHPとHTMLを使って行うことは可能ですか、それともそこに何らかのJS\jQueryが必要でしょうか? :)

1
thePHPn00b

このようにあなた自身のアップロードフォームを実装することは重大なセキュリティ上の脆弱性になる可能性があります、そのような潜在的な問題がすでに適切に対処されているところでライブラリ/スクリプトを代わりに使用したいかもしれません。

これは私が同じ目的のためにプロジェクトでうまく使ったことを思い出したものです(ユーザーがアップロードしたビデオ)...それはあなたが必要とするもの以上であるかもしれませんが、それは単純化されたウェブの例より多くの例とドキュメンテーションを持ちます: PL Upload

編集:私はちょうどそのプロジェクトのための私の予備のアップローダであったことを思い出しました、それが大きいファイルのためにファイル再開をサポートするので - 使われた主なものは ResumeableJS (ビデオアップロードにとても便利です!)

2
majick