1

私はワードプレスでページを作成し、その中にこのフォームを入れました。

<form action=""method="post"enctype="multipart/form-data">
<input type="file" name="file"><br>
<input type="text" placeholder="Your Name" name="name" />
<input type="submit" name="submit" value="Submit">
</form>

送信をクリックすると、ユーザーがアップロードした写真をフォルダー wp-content/uploads/[posted user name] に保存する必要があります

ワードプレスのバックエンド処理部分について誰か助けてください。wp_upload_bits を試してみましたが、うまくいきませんでした。

前もって感謝します。

4

1 に答える 1

5

wordpress のユーザー insert_attachment を使用して添付ファイルを保存すると、さまざまなスタイルの画像を取得する機能 get_attachment(id, 'full/medium/thumbnail') も利用できるようになります。

$files = $_FILES['upload_attachment'];
foreach ($_FILES as $file => $array) {
  $newupload = insert_attachment($file,null);
  // save the $newupload with you from data, as psot id for the 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 で、フォームを送信すると、画像がアップロードされ、参照が wp_post テーブルに保存されます

<form action="upload_file.php" method="post" enctype="multipart/form-data">
   <label for="file">Filename:</label>
   <input type="file" name="upload_attachment[]" id="file"><br>
   <label for="file">Filename:</label>
   <input type="file" name="upload_attachment[]" id="file"><br>
   <label for="file">Filename:</label>
   <input type="file" name="upload_attachment[]" id="file"><br>
   <input type="submit" name="submit" value="Submit">
</form>
于 2013-06-07T10:59:37.473 に答える