2015-08-09 1 views
0

Я разработчик Android. Я сделал php-файл на моем хосте, и я включил wp-blog-header.php. Я использовал этот файл как веб-сервис.Искать только в заголовках сообщений в wordpress, чтобы получить заголовок и идентификатор

В моем приложении есть часть поиска, и я получаю term как String и category как идентификатор пользователя и отправляю их в файл php.

Теперь я хотел бы искать в заголовках сообщений и возвращать названия и идентификаторы того, что пользователь хочет.

function customSearch($term,$category){ 
. 
. 
. 

} 

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

function getLastItems() 
{ 



    $args = array(
     'numberposts' => 5, 
     'offset' => 0, 
     'category' => 0, 
     'orderby' => 'post_date', 
     'order' => 'DESC', 
     'post_type' => 'post', 
     'post_status' => 'publish', 
     'suppress_filters' => true); 

    $recent_posts = wp_get_recent_posts($args, ARRAY_A); 

    $mjson = array(); 


    foreach($recent_posts as $recent){ 

     $thumb = wp_get_attachment_image_src(get_post_thumbnail_id($recent['ID']), array(400,300)); 
     $url_img = $thumb['0']; 

     $marr = array(
      'id'=>$recent["ID"], 
      'title'=>$recent["post_title"], 
      'img'=>$url_img 
     ); 

     array_push($mjson,$marr); 

    } 

    return $mjson ; 



}//end get last items 

ответ

2

Я не понимаю вашу поисковую часть, но ваш вопрос по поиску в только заголовке, этот ответ будет для вас.

  1. Добавить фильтр для поиска только в заголовке, перед поиском.
  2. Удалить фильтр после поиска.

Если вы хотите найти в заголовке, просто добавьте ниже args.

function search_by_title($search, $wp_query) { 
    if (! empty($search) && ! empty($wp_query->query_vars['search_terms'])) { 
     global $wpdb; 

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

     $search = array(); 

     foreach ((array) $q['search_terms'] as $term) 
      $search[] = $wpdb->prepare("$wpdb->posts.post_title LIKE %s", $n . $wpdb->esc_like($term) . $n); 

     if (! is_user_logged_in()) 
      $search[] = "$wpdb->posts.post_password = ''"; 

     $search = ' AND ' . implode(' AND ', $search); 
    } 

    return $search; 
} 


$args = array(
    's' => 'search string', 
    'numberposts' => 5, 
    'offset' => 0, 
    'category' => 0, 
    'orderby' => 'post_date', 
    'order' => 'DESC', 
    'post_type' => 'post', 
    'post_status' => 'publish', 
    'suppress_filters' => true); 

add_filter('posts_search', 'search_by_title', 10, 2); 
$recent_posts = wp_get_recent_posts($args, ARRAY_A); 
remove_filter('posts_search', 'search_by_title', 500); 


foreach($recent_posts as $posts) { 

    // your custom code here 
} 
+0

0k, plz дайте мне полную функцию! потому что я в замешательстве. –

+0

@ S.M_Emamian Я обновил код. – Noman

Смежные вопросы