Как получить URL запроса Solr из объекта ответа в drupal 7? - PullRequest
0 голосов
/ 17 апреля 2019

Я действительно хочу напечатать полный запрос для пользовательского решения.

Я использую этот код для получения результата от solr:

Пример:

  $solr = apachesolr_get_solr('name_of_solr');
  if($solr->ping()) {
      $params = array(
      'q' => '*',
      'start' => 0,
      'rows' => 20,
      'fl' => 'entity_id',
      );
      $query = new SolrBaseQuery('apachesolr', $solr, $params, '');
      $query->addParam('sort', 'ss_published_date desc'); 
      $query->addFilter('im_field_section', $sc_id);
  }
  $response = $query->search();

Я пытаюсь получить полный запрос или URL по

dpm($query);//Getting object..

Ожидаемый результат:

http://11.11.111.111:8983/solr/tod/select?fl=entity_id&fq=im_field_section:%20174&indent=on&q=*:*&rows=20&sort=ss_published_date%20desc&start=0&wt=json

Ответы [ 2 ]

0 голосов
/ 21 июня 2019

Если вы добавите echoParams в свой запрос solr, вы получите более подробную информацию о вашем запросе, а затем сможете объединить их для создания исходной строки запроса.

https://lucene.apache.org/solr/guide/6_6/common-query-parameters.html#CommonQueryParameters-TheechoParamsParameter

0 голосов
/ 17 апреля 2019

Мы можем получить полный URL-адрес запроса, прочитав ключ массива [запрос] из объекта ответа:

drupal_set_message(print_r($response, TRUE));

# output :
stdClass Object ( [request] => GET /solr/tod/select?start=0&rows=1&fq=sm_outlet_relations%3A12702&fq=im_field_section%3A44&q=%2A&fl=entity_id&sort=ss_published_date%20desc&wt=json&json.nl=map HTTP/1.0 User-Agent: Drupal (+http://drupal.org/) Host: my_host [data] => {"response":{"numFound":1,"start":0,"docs":[{"entity_id":582143}]}} [protocol] => HTTP/1.1 [status_message] => OK [headers] => Array ( [content-type] => text/plain;charset=utf-8 [content-length] => 68 ) [code] => 200 [response] => stdClass Object ( [numFound] => 1 [start] => 0 [docs] => Array ( [0] => stdClass Object ( [entity_id] => 582143 ) ) ) ) 

Или просто:

dpm($response->request);

# output :
GET /solr/tod/select?start=0&rows=1&fq=sm_outlet_relations%3A12702&fq=im_field_section%3A44&q=%2A&fl=entity_id&sort=ss_published_date%20desc&wt=json&json.nl=map HTTP/1.0 User-Agent: Drupal (+http://drupal.org/) Host: my_host 
...