Formatação adequada de post_date para wp_insert_post?

10

Qual é a maneira correta de definir a data da postagem ao enviar uma postagem pelo front-end usando wp_insert_post ( Trac )?

Meu snippet agora está publicando com o tempo do 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
fonte

Respostas:

23

Se você não adicionar um post_date, o WordPress o preenche automaticamente com a data e hora atuais.

Definir outra data e hora [ Y-m-d H:i:s ]é a estrutura certa. Um exemplo abaixo com o seu código.

$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
fonte
Obrigado Rob! Adicionando $postdate = date('2010-02-23 18:57:33');realmente faz caixas de entrada parar de funcionar, talvez isso é apenas um bug no Chrome embora ...
m-Torin
11
Eu mesmo tentei e funciona. Talvez o seu problema esteja em outro lugar no seu código.
Rob Vermeer
Eu tentei usar que formatação data, e ele está retornandoNotice: A non well formed numeric value encountered in C:\xampp\htdocs\wordpress\wp-includes\functions.php on line 4028
Ari
2
deve ser $postdate = '2010-02-23 18:57:33';, porque date()requer um formato de data literal para processar, não números. Ou$postdate = date('Y-m-d H:i:s', strtotime('2010-02-23 18:57:33'));
Alex K
3

Para converter sua data no formato Wordpress (MySQL DATETIME), tente o seguinte:

$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);

ou, claro, se você realmente quer ser sexy, faça o seguinte:

'post_date'     => date("Y-m-d H:i:s", strtotime("Sept 11, 2001"))
JP Lew
fonte
Isso é muito útil para formatar um carimbo de data / hora do Unix, especificamente o date("Y-m-d H:i:s", $date_stamp)código.
David
2

Você não pode formatar o $_POST['date']assim ... você vai ter que correr o valor de $_POST['date']por algo assim $postdate = date( $_POST['date'] )... Há também a possibilidade de get_Option chamada para as configurações do blog. Consulte Referência das opções no Codex.

kaiser
fonte
Usar Data realmente quebrou a postagem e retornaria um erro 404. Obrigado Kaiser pela direção!
M-torin
2

Para a comunidade, aqui está o meu código de trabalho final:

cabeçalho

$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
fonte
0

deparei com google. Eu sei que é velho, mas não há resposta definitiva. código wordpress usa current_time( 'mysql' )para salvar data / hora na função wp_update_post! isso irá gerar o formato de data desejado.

Nic Bug
fonte