當前位置: 首頁>>代碼示例>>PHP>>正文


PHP SimpleXmlElement::getNameSpaces方法代碼示例

本文整理匯總了PHP中SimpleXmlElement::getNameSpaces方法的典型用法代碼示例。如果您正苦於以下問題:PHP SimpleXmlElement::getNameSpaces方法的具體用法?PHP SimpleXmlElement::getNameSpaces怎麽用?PHP SimpleXmlElement::getNameSpaces使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在SimpleXmlElement的用法示例。


在下文中一共展示了SimpleXmlElement::getNameSpaces方法的4個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: process

 /**
  * Translate Primo's XML into array of arrays.
  *
  * @param array $data The raw xml from Primo
  *
  * @return array      The processed response from Primo
  */
 protected function process($data)
 {
     $res = parent::process($data);
     // Load API content as XML objects
     $sxe = new \SimpleXmlElement($data);
     if ($sxe === false) {
         throw new \Exception('Error while parsing the document');
     }
     // Register the 'sear' namespace at the top level to avoid problems:
     $sxe->registerXPathNamespace('sear', 'http://www.exlibrisgroup.com/xsd/jaguar/search');
     // Get the available namespaces. The Primo API uses multiple namespaces.
     // Will be used to navigate the DOM for elements that have namespaces
     $namespaces = $sxe->getNameSpaces(true);
     $docset = $sxe->xpath('//sear:DOC');
     if (empty($docset) && isset($sxe->JAGROOT->RESULT->DOCSET->DOC)) {
         $docset = $sxe->JAGROOT->RESULT->DOCSET->DOC;
     }
     for ($i = 0; $i < count($docset); $i++) {
         $doc = $docset[$i];
         // Set OpenURL
         $sear = $doc->children($namespaces['sear']);
         if ($openUrl = $this->getOpenUrl($sear)) {
             $res['documents'][$i]['url'] = $openUrl;
         } else {
             unset($res['documents'][$i]['url']);
         }
         // Prefix records id's
         $res['documents'][$i]['recordid'] = 'pci.' . $res['documents'][$i]['recordid'];
         // Process highlighting
         if ($this->highlighting) {
             // VuFind strips Primo highlighting tags from the description,
             // so we need to re-read the field (preserving highlighting tags).
             $description = isset($doc->PrimoNMBib->record->display->description) ? (string) $doc->PrimoNMBib->record->display->description : (string) $doc->PrimoNMBib->record->search->description;
             $description = trim(mb_substr($description, 0, 2500, 'UTF-8'));
             // these may contain all kinds of metadata, and just stripping
             //   tags mushes it all together confusingly.
             $description = str_replace("P>", "p>", $description);
             $d_arr = explode("<p>", $description);
             foreach ($d_arr as &$value) {
                 $value = trim($value);
                 if (trim(strip_tags($value)) === '') {
                     // get rid of entries that would just have spaces
                     unset($d_arr[$value]);
                 }
             }
             // now all paragraphs are converted to linebreaks
             $description = implode("<br>", $d_arr);
             $res['documents'][$i]['description'] = $description;
             $fieldList = ['title' => 'title', 'creator' => 'author', 'description' => 'description'];
             $start = '<span class="searchword">';
             $end = '</span>';
             $hilited = [];
             foreach ($fieldList as $field => $hiliteField) {
                 if (!isset($res['documents'][$i][$field])) {
                     continue;
                 }
                 $val = $res['documents'][$i][$field];
                 $values = is_array($val) ? $val : [$val];
                 $valuesHilited = [];
                 foreach ($values as $val) {
                     if (stripos($val, $start) !== false && stripos($val, $end) !== false) {
                         // Replace Primo hilite-tags
                         $hilitedVal = $val;
                         $hilitedVal = str_replace($start, '{{{{START_HILITE}}}}', $hilitedVal);
                         $hilitedVal = str_replace($end, '{{{{END_HILITE}}}}', $hilitedVal);
                         $valuesHilited[] = $hilitedVal;
                         // Strip Primo hilite-tags from record fields
                         $val = str_replace($start, '', $val);
                         $val = str_replace($end, '', $val);
                         $res['documents'][$i][$field] = is_array($res['documents'][$i][$field]) ? [$val] : $val;
                     }
                 }
                 if (!empty($valuesHilited)) {
                     $hilited[$hiliteField] = $valuesHilited;
                 }
             }
             $res['documents'][$i]['highlightDetails'] = $hilited;
         }
     }
     return $res;
 }
開發者ID:samuli,項目名稱:vufind-ere,代碼行數:88,代碼來源:Connector.php

示例2: get_namespaces_from_feed

	/**
	 * Detects the namespaces used the in feed.
	 * 
	 * @since 2.8
	 */
	public static function get_namespaces_from_feed() {
		// Get the feed source from POST data
		$feed_source = ( isset($_POST['feed_source']) )? $_POST['feed_source'] : NULL;
		// If no feed source is given, or an empty feed source is given, print an error message
		if ( $feed_source === '' || $feed_source === NULL ) {
			die( __('Invalid feed source given.', WPRSS_TEXT_DOMAIN) );
		}

		// Read the feed source
		$feed = @file_get_contents( $feed_source );
		// Show an error 
		if ( $feed === FALSE ) {
			die( __( 'Failed to read feed source XML. Check that your URL is a valid feed source URL', WPRSS_TEXT_DOMAIN ) );
		}

		try {
			// Parse the XML
			$xml = new SimpleXmlElement($feed);
			// Get the namespaces
			$namespaces = $xml->getNameSpaces(true);
			// Unset the standard RSS and XML namespaces
			unset( $namespaces[''] );
			unset( $namespaces['xml'] );
			// Print the remaining namespaces as an encoded JSON string
			die( json_encode( $namespaces ) );
		}
		catch( Exception $e ) {
			die( __( 'Failed to parse the RSS feed XML. The feed may contain errors or is not a valid feed source.', WPRSS_TEXT_DOMAIN ) );
		}
	}
開發者ID:acutedeveloper,項目名稱:carepoint-development,代碼行數:35,代碼來源:wprss-ftp-utils.php

示例3: process

 /**
  * Translate Primo's XML into array of arrays.
  *
  * @param array $data The raw xml from Primo
  *
  * @return array      The processed response from Primo
  */
 protected function process($data)
 {
     // make sure data exists
     if (strlen($data) == 0) {
         throw new \Exception('Primo did not return any data');
     }
     // Load API content as XML objects
     $sxe = new \SimpleXmlElement($data);
     if ($sxe === false) {
         throw new \Exception('Error while parsing the document');
     }
     // some useful data about these results
     $totalhitsarray = $sxe->xpath("//@TOTALHITS");
     // if totalhits is missing but we have a message, this is an error
     // situation.
     if (!isset($totalhitsarray[0])) {
         $messages = $sxe->xpath("//@MESSAGE");
         $message = isset($messages[0]) ? (string) $messages[0] : "TOTALHITS attribute missing.";
         throw new \Exception($message);
     } else {
         $totalhits = (int) $totalhitsarray[0];
     }
     // TODO: would these be useful?
     //$firsthit = $sxe->xpath('//@FIRSTHIT');
     //$lasthit = $sxe->xpath('//@LASTHIT');
     // Register the 'sear' namespace at the top level to avoid problems:
     $sxe->registerXPathNamespace('sear', 'http://www.exlibrisgroup.com/xsd/jaguar/search');
     // Get the available namespaces. The Primo API uses multiple namespaces.
     // Will be used to navigate the DOM for elements that have namespaces
     $namespaces = $sxe->getNameSpaces(true);
     // Get results set data and add to $items array
     // This foreach grabs all the child elements of sear:DOC,
     //   except those with namespaces
     $items = [];
     $docset = $sxe->xpath('//sear:DOC');
     if (empty($docset) && isset($sxe->JAGROOT->RESULT->DOCSET->DOC)) {
         $docset = $sxe->JAGROOT->RESULT->DOCSET->DOC;
     }
     foreach ($docset as $doc) {
         $item = [];
         // Due to a bug in the primo API, the first result has
         //   a namespace (prim:) while the rest of the results do not.
         //   Those child elements do not get added to $doc.
         //   If the bib parent element (PrimoNMBib) is missing for a $doc,
         //   that means it has the prim namespace prefix.
         // So first set the right prefix
         $prefix = $doc;
         if ($doc->PrimoNMBib != 'true' && isset($namespaces['prim'])) {
             // Use the namespace prefix to get those missing child
             //   elements out of $doc.
             $prefix = $doc->children($namespaces['prim']);
         }
         // Now, navigate the DOM and set values to the array
         // cast to (string) to get the element's value not an XML object
         $item['recordid'] = substr((string) $prefix->PrimoNMBib->record->control->recordid, 3);
         $item['title'] = (string) $prefix->PrimoNMBib->record->display->title;
         // format
         $item['format'] = ucwords(str_replace('_', ' ', (string) $prefix->PrimoNMBib->record->display->type));
         // creators
         $creator = trim((string) $prefix->PrimoNMBib->record->display->creator);
         if (strlen($creator) > 0) {
             $item['creator'] = array_map('trim', explode(';', $creator));
         }
         // subjects
         $subject = trim((string) $prefix->PrimoNMBib->record->display->subject);
         if (strlen($subject) > 0) {
             $item['subjects'] = explode(';', $subject);
         }
         $item['ispartof'] = (string) $prefix->PrimoNMBib->record->display->ispartof;
         // description is sort of complicated
         // TODO: sometimes the entire article is in the description.
         $description = isset($prefix->PrimoNMBib->record->display->description) ? (string) $prefix->PrimoNMBib->record->display->description : (string) $prefix->PrimoNMBib->record->search->description;
         $description = trim(mb_substr($description, 0, 2500, 'UTF-8'));
         // these may contain all kinds of metadata, and just stripping
         //   tags mushes it all together confusingly.
         $description = str_replace("P>", "p>", $description);
         $d_arr = explode("<p>", $description);
         foreach ($d_arr as &$value) {
             // strip tags, trim so array_filter can get rid of
             // entries that would just have spaces
             $value = trim(strip_tags($value));
         }
         $d_arr = array_filter($d_arr);
         // now all paragraphs are converted to linebreaks
         $description = implode("<br>", $d_arr);
         $item['description'] = $description;
         // and the rest!
         $item['language'] = (string) $prefix->PrimoNMBib->record->display->language;
         $item['source'] = implode('; ', (array) $prefix->PrimoNMBib->record->display->source);
         $item['identifier'] = (string) $prefix->PrimoNMBib->record->display->identifier;
         $item['fulltext'] = (string) $prefix->PrimoNMBib->record->delivery->fulltext;
         $item['issn'] = [];
         foreach ($prefix->PrimoNMBib->record->search->issn as $issn) {
//.........這裏部分代碼省略.........
開發者ID:grharry,項目名稱:vufind,代碼行數:101,代碼來源:Connector.php

示例4: _loadXML

 private function _loadXML()
 {
     $feed = file_get_contents($this->_query_link);
     $xml = new SimpleXmlElement($feed);
     //Use that namespace
     $namespaces = $xml->getNameSpaces(true);
     //Now we don't have the URL hard-coded
     $dc = (array) $xml->children($namespaces['dc']);
     //load data to $this->this results
     foreach ($dc as $key => $value) {
         switch ($key) {
             case 'creator':
                 $this->_fetchAuthors($value);
                 break;
             case 'identifier':
                 $this->_fetchIds($value);
                 break;
             case 'title':
                 $this->_fetchTitle($value);
                 break;
             case 'publisher':
                 $this->_fetchPublisher($value);
                 break;
             case 'language':
                 $this->_fetchLanguage($value);
                 break;
             case 'description':
                 $this->_fetchDescription($value);
                 break;
             case 'subject':
                 $this->_fetchSubject($value);
                 break;
             case 'format':
                 $this->_fetchFormat($value);
                 break;
         }
     }
 }
開發者ID:eldorplus,項目名稱:isbn_search,代碼行數:38,代碼來源:google_query.php


注:本文中的SimpleXmlElement::getNameSpaces方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。