Ошибка разрешения JSON?


У меня есть два выпадающих списка для фильтрации сообщений на веб-сайте. Второй раскрывающийся список заполняется на основе выбора первого, т. Е.:

[CATEGORY] + [SUB-CATEGORY] = SEARCH

Проблема в том, что иногда второй раскрывающийся список не заполняется, и консоль показывает:

POST: http://localhost/site/wp-admin/admin-ajax.php
{"html":"","error":"Permission error"}

Что это на самом деле означает? И как бы я это исправил? Это код, который возвращает ошибку:

add_action( 'wp_ajax_wpse158929_get_terms_for_cpt', 'wpse158929_get_terms_for_cpt' );
add_action( 'wp_ajax_nopriv_wpse158929_get_terms_for_cpt', 'wpse158929_get_terms_for_cpt' );

function wpse158929_get_terms_for_cpt() {
$ret = array( 'html' => '', 'error' => false );

if ( ! check_ajax_referer( 'wpse158929_get_terms_for_cpt_submit_', 'nonce', false /*die*/ ) ) {
$ret['error'] = __( 'Permission error', 'wpfm' );
} else {
$post_type = isset( $_REQUEST['post_type'] ) ? $_REQUEST['post_type'] : '';
$taxonomy = isset( $_REQUEST['taxonomy'] ) ? $_REQUEST['taxonomy'] : '';
$current_selected = isset( $_REQUEST['current_selected'] ) ? $_REQUEST['current_selected'] : '';

if ( ! $post_type || ! $taxonomy ) {
    $ret['error'] = __( 'Params error', 'wpfm' );
} else {
    global $wpdb;
    $sql = $wpdb->prepare( 'SELECT t.slug FROM ' . $wpdb->terms . ' t'
        . ' JOIN ' . $wpdb->term_taxonomy . ' AS tt ON tt.term_id = t.term_id'
        . ' JOIN ' . $wpdb->term_relationships . ' AS tr ON tr.term_taxonomy_id = tt.term_taxonomy_id'
        . ' JOIN ' . $wpdb->posts . ' AS p ON p.ID = tr.object_id'
        . ' WHERE tt.taxonomy = %s AND p.post_type = %s AND p.post_status = %s'
        . ' GROUP BY t.slug'
        , $taxonomy, $post_type, 'publish' );
    $include = $wpdb->get_col($sql);
    $ret['html'] = preg_replace( '/<\/?select[^>]*>/', '', my_dropdown_categories( $taxonomy, $current_selected, $include ) );
}
}

wp_send_json( $ret );
}

Большое спасибо:)

Author: Guit4eva, 2015-02-09

1 answers

Ваша проблема в том, что вы проверяете наличие nonce, а nonce устарел. Трудно сделать конкретный комментарий о необходимости использования nonce в вашем случае, но в целом nonce следует использовать только для отправки данных, а не для запроса.

 1
Author: Mark Kaplun, 2015-02-09 08:32:32