Pemformatan post_date untuk wp_insert_post yang benar?

10

Apa cara yang tepat untuk menentukan tanggal posting ketika mengirimkan posting dari ujung depan menggunakan wp_insert_post ( Trac )?

Cuplikan saya sekarang diterbitkan dengan waktu mysql ...

if (isset ($_POST['date'])) {
    $postdate = $_POST['Y-m-d'];
}
else {
    $postdate = $_POST['2011-12-21'];
}

// ADD THE FORM INPUT TO $new_post ARRAY
$new_post = array(
'post_title'    =>   $title,
'post_content'  =>   $description,
'post_date'     =>   $postdate,
'post_status'   =>   'publish',
'post_parent' => $parent_id,
'post_author' => get_current_user_id(),
);

//SAVE THE POST
$pid = wp_insert_post($new_post);
m-torin
sumber

Jawaban:

23

Jika Anda tidak menambahkan post_date maka WordPress mengisinya secara otomatis dengan tanggal dan waktu saat ini.

Untuk menetapkan tanggal dan waktu lain [ Y-m-d H:i:s ]adalah struktur yang tepat. Contoh di bawah ini dengan kode Anda.

$postdate = '2010-02-23 18:57:33';

$new_post = array(
   'post_title'    =>   $title,
   'post_content'  =>   $description,
   'post_date'     =>   $postdate,
   'post_status'   =>   'publish',
   'post_parent'   =>   $parent_id,
   'post_author'   =>   get_current_user_id(),
);

//SAVE THE POST
$pid = wp_insert_post($new_post);
Rob Vermeer
sumber
Rob terima kasih! Menambahkan $postdate = date('2010-02-23 18:57:33');sebenarnya membuat kotak input berhenti berfungsi, mungkin itu hanya bug di Chrome ...
m-torin
1
Saya sudah mencobanya sendiri dan berhasil. Mungkin masalah Anda ada di tempat lain dalam kode Anda.
Rob Vermeer
Saya mencoba menggunakan format tanggal itu, dan itu kembaliNotice: A non well formed numeric value encountered in C:\xampp\htdocs\wordpress\wp-includes\functions.php on line 4028
Ari
2
seharusnya $postdate = '2010-02-23 18:57:33';, karena date()memerlukan format tanggal literal untuk diproses, bukan angka. Atau$postdate = date('Y-m-d H:i:s', strtotime('2010-02-23 18:57:33'));
Alex K
3

untuk mengonversi tanggal Anda ke format Wordpress (MySQL DATETIME), coba ini:

$date_string = "Sept 11, 2001"; // or any string like "20110911" or "2011-09-11"
// returns: string(13) "Sept 11, 2001"

$date_stamp = strtotime($date_string);
// returns: int(1000166400)

$postdate = date("Y-m-d H:i:s", $date_stamp);
// returns: string(19) "2001-09-11 00:00:00"

$new_post = array(
    // your other arguments
   'post_date'     =>   $postdate
);

$pid = wp_insert_post($new_post);

atau tentu saja jika Anda ingin benar-benar menjadi seksi lakukan ini:

'post_date'     => date("Y-m-d H:i:s", strtotime("Sept 11, 2001"))
JP Lew
sumber
Ini sangat membantu untuk memformat cap waktu Unix, khususnya date("Y-m-d H:i:s", $date_stamp)kodenya.
David
2

Anda tidak dapat memformat $_POST['date']seperti ini ... Anda harus menjalankan nilai dari $_POST['date']sesuatu seperti $postdate = date( $_POST['date'] )... Ada juga kemungkinan untuk memanggil get_option untuk pengaturan blog. Lihat Referensi Opsi di Codex.

kaisar
sumber
Menggunakan Date sebenarnya mematahkan postingan dan akan mengembalikan kesalahan 404. Terima kasih Kaiser untuk arahannya!
m-torin
2

Untuk komunitas di sini adalah kode kerja terakhir saya:

tajuk

$year = $_REQUEST['year'];
$month = $_REQUEST['month'];
$day = $_REQUEST['day'];
$postdate =  $year . "-" . $month . "-" . $day . " 08:00:00";

$new_post = array(
    'post_title'    =>  $title,
    'post_content'  =>  $description,
    'post_status'   =>  'publish',
    'post_author'   =>  get_current_user_id(),
    'post_date'     =>  $postdate
);
m-torin
sumber
0

datang melalui google. saya tahu yang lama tetapi tidak ada jawaban yang pasti. kode wordpress digunakan current_time( 'mysql' )untuk menyimpan tanggal / waktu dalam fungsi wp_update_post! ini akan menghasilkan format tanggal yang diinginkan.

Nic Bug
sumber