Je reçois un avis lorsque j'essaie d'ajouter un nouveau message dans deux taxonomies différentes, dans l'une j'utilise une méta-boîte personnalisée et dans l'autre pas, cependant l'avis apparaît pour les deux lorsque j'essaie d'ajouter un nouvel élément, je vois this: Remarque: Index indéfini: nom_nom_produit dans/Applications/MAMP/htdocs/site/wordpress/wp-content/themes/theme/functions.php à la ligne 259, un peu en dessous de la bande noire supérieure dans WP Admin
La ligne 259 est:
if ( !wp_verify_nonce( $_POST['product_noncename'], plugin_basename(__FILE__) )) {
qui en fait partie:
// Save the Metabox Data
function wpt_save_product_meta($post_id, $post) {
// verify this came from the our screen and with proper authorization,
// because save_post can be triggered at other times
if ( !wp_verify_nonce( $_POST['product_noncename'], plugin_basename(__FILE__) )) {
return $post->ID;
}
// Is the user allowed to edit the post or page?
if ( !current_user_can( 'edit_post', $post->ID ))
return $post->ID;
// OK, we're authenticated: we need to find and save the data
// We'll put it into an array to make it easier to loop though.
$product_meta['_location'] = $_POST['_location'];
$product_meta['_asiaLoc'] = $_POST['_asiaLoc'];
$product_meta['_europeLoc'] = $_POST['_europeLoc'];
$product_meta['_isbn'] = $_POST['_isbn'];
$product_meta['_orderform'] = $_POST['_orderform'];
// Add values of $events_meta as custom fields
foreach ($product_meta as $key => $value) { // Cycle through the $events_meta array!
if( $post->post_type == 'revision' ) return; // Don't store custom data twice
$value = implode(',', (array)$value); // If $value is an array, make it a CSV (unlikely)
if(get_post_meta($post->ID, $key, FALSE)) { // If the custom field already has a value
update_post_meta($post->ID, $key, $value);
} else { // If the custom field doesn't have a value
add_post_meta($post->ID, $key, $value);
}
if(!$value) delete_post_meta($post->ID, $key); // Delete if blank
}
}
add_action('save_post', 'wpt_save_product_meta', 1, 2); // save the custom fields
// Save the Metabox Data
function wpt_save_product_meta($post_id, $post) {
if($post->post_type!='post type with metabox') {
return $post->ID;
}
// verify this came from the our screen and with proper authorization,
// because save_post can be triggered at other times
if ( !wp_verify_nonce( $_POST['product_noncename'], plugin_basename(__FILE__) )) {
return $post->ID;
}
// Is the user allowed to edit the post or page?
if ( !current_user_can( 'edit_post', $post->ID ))
return $post->ID;
// OK, we're authenticated: we need to find and save the data
// We'll put it into an array to make it easier to loop though.
$product_meta['_location'] = $_POST['_location'];
$product_meta['_asiaLoc'] = $_POST['_asiaLoc'];
$product_meta['_europeLoc'] = $_POST['_europeLoc'];
$product_meta['_isbn'] = $_POST['_isbn'];
$product_meta['_orderform'] = $_POST['_orderform'];
// Add values of $events_meta as custom fields
foreach ($product_meta as $key => $value) { // Cycle through the $events_meta array!
if( $post->post_type == 'revision' ) return; // Don't store custom data twice
$value = implode(',', (array)$value); // If $value is an array, make it a CSV (unlikely)
if(get_post_meta($post->ID, $key, FALSE)) { // If the custom field already has a value
update_post_meta($post->ID, $key, $value);
} else { // If the custom field doesn't have a value
add_post_meta($post->ID, $key, $value);
}
if(!$value) delete_post_meta($post->ID, $key); // Delete if blank
}
}
add_action('save_post', 'wpt_save_product_meta', 1, 2); // save the custom fields
Il suffit de vérifier si $_POST['product_noncename']
est défini en premier, alors changez cette ligne:
if ( !wp_verify_nonce( $_POST['product_noncename'], plugin_basename(__FILE__) )) {
pour ça:
if ( !isset($_POST['product_noncename']) || !wp_verify_nonce( $_POST['product_noncename'], plugin_basename(__FILE__) )) {
S'appuyant sur la réponse de Bainternet, cela a fonctionné pour moi:
if ( !isset($_POST['product_noncename']) || !wp_verify_nonce( $_POST['product_noncename'], basename(__FILE__) )) {
Notez la différence entre plugin_basename et basename.