WP rest API получить пост по заголовку

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

http://domain.com/wp-json/wp/v2/posts?filter[post-title]=table

Я хочу, чтобы пост с таблицей имен существовал, чтобы получить пост, если нет, получить пустой ответ. Но по какой-то причине, когда сообщение с заголовком не существует, я получаю все сообщения обратно. Как можно получить пустое, когда нет поста и пост, когда он существует.

3 ответа

К сожалению, это невозможно, но вместо этого вы можете использовать слаг. Slug - это редактируемая часть URL-адреса при написании сообщения, которая может представлять заголовок страницы (или его можно изменить на это).

http://example.com/wp-json/wp/v2/posts?slug=table

Более подробная информация: https://developer.wordpress.org/rest-api/reference/pages/

Согласно http://v2.wp-api.org/, некоторые должны использовать search ключевое слово:
http://domain.com/wp-json/wp/v2/posts?search=table,

Вы не можете сделать это через wp json, скопируйте следующий код в functions.php:

      function __search_by_title_only( $search, &$wp_query ) {
    global $wpdb;

    if ( empty( $search ) )
        return $search; // skip processing - no search term in query

    $q = $wp_query->query_vars;    
    $n = ! empty( $q['exact'] ) ? '' : '%';

    $search =
    $searchand = '';

    foreach ( (array) $q['search_terms'] as $term ) {
        $term = esc_sql( like_escape( $term ) );
        $search .= "{$searchand}($wpdb->posts.post_title LIKE '{$n}{$term}{$n}')";
        $searchand = ' AND ';
    }

    if ( ! empty( $search ) ) {
        $search = " AND ({$search}) ";
        if ( ! is_user_logged_in() )
            $search .= " AND ($wpdb->posts.post_password = '') ";
    }

    return $search;
}
add_filter( 'posts_search', '__search_by_title_only', 500, 2 );
Другие вопросы по тегам