Der folgende Code erstellt erfolgreich einen benutzerdefinierten Beitrag und fügt ihm Meta-Details hinzu. Der Code lädt auch hochgeladene Bilder in einen Uploads-Ordner im Stammverzeichnis der Website. Ich stecke beim Erstellen eines foreach-Arguments fest, um die Bilddateipfade als Textzeichenfolgen in die folgenden benutzerdefinierten Felder zu schreiben: image_1, image_2, image_3 und image_4.
<?php
if(isset($_POST['url']) && $_POST['url'] == ''){
require('../wp-load.php');
$a = $_POST['a'];
$b = $_POST['b'];
$c = $_POST['c'];
$d = $_POST['d'];
$e = $_POST['e'];
include('../src/class.fileuploader.php');
$FileUploader = new FileUploader('files', array(
'uploadDir' => '../uploads/',
'title' => 'name'
));
$data = $FileUploader->upload();
if($data['isSuccess'] && count($data['files']) > 0) {
$uploadedFiles = $data['files'];
}
if($data['hasWarnings']) {
$warnings = $data['warnings'];
echo '<pre>';
print_r($warnings);
echo '</pre>';
exit;
}
foreach($FileUploader->getRemovedFiles('file') as $key=>$value) {
unlink('../uploads/' . $value['name']);
}
$my_post = array(
'ID' => '',
'post_title' => wp_strip_all_tags($_POST['a']),
'post_content' => $_POST['d'],
'post_status' => 'draft',
'post_type' => 'custompost'
);
$post_id = wp_insert_post($my_post);
add_post_meta($post_id, 'b', $b, true);
add_post_meta($post_id, 'c', $c, true);
add_post_meta($post_id, 'e', $e, true);
add_post_meta($post_id, 'image_1', $image_1, true);
add_post_meta($post_id, 'image_2', $image_2, true);
add_post_meta($post_id, 'image_3', $image_3, true);
add_post_meta($post_id, 'image_4', $image_4, true);
header('Location: http://www.example.com/thank-you/');
} else {
header('Location: http://www.example.com/thank-you/');
}
?>
Mögliches Duplikat von Front-End Media Uploading in WordPress
– Michael Doye
26. Juni 2017 um 13:24 Uhr