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


PHP Sanitizer::decodeCharReferences方法代碼示例

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


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

示例1: _stripMarkup

 /**
  * Strip markup to show plaintext
  * @param string $text
  * @return string
  * @access private
  */
 function _stripMarkup($text)
 {
     global $wgContLang;
     $text = substr($text, 0, 4096);
     // don't bother with long text...
     $text = str_replace("'''", "", $text);
     $text = str_replace("''", "", $text);
     $text = preg_replace('#__[a-z0-9_]+__#i', '', $text);
     // magic words
     $cleanChar = "[^|\\[\\]]";
     $subLink = "\\[\\[{$cleanChar}*(?:\\|{$cleanChar}*)*\\]\\]";
     $pipeContents = "(?:{$cleanChar}|{$subLink})*";
     $text = preg_replace_callback("#\n\t\t\t\\[\\[\n\t\t\t\t({$cleanChar}*)\n\t\t\t\t(?:\\|({$pipeContents}))?\n\t\t\t\t(?:\\|{$pipeContents})*\n\t\t\t\\]\\]\n\t\t\t#six", array($this, '_stripLink'), $text);
     $protocols = wfUrlProtocols();
     $text = preg_replace('#\\[(?:$protocols).*? (.*?)\\]#s', '$1', $text);
     // URL links
     $text = preg_replace('#</?[a-z0-9]+.*?>#s', '', $text);
     // HTML-style tags
     $text = preg_replace('#\\{\\|.*?\\|\\}#s', '', $text);
     // tables
     $text = preg_replace('#^:.*$#m', '', $text);
     // indented lines near start are usually disambigs or notices
     $text = Sanitizer::decodeCharReferences($text);
     return trim($text);
 }
開發者ID:realsoc,項目名稱:mediawiki-extensions,代碼行數:31,代碼來源:IndexAbstracts.php

示例2: generateDBKey

 private static function generateDBKey($title, $conn)
 {
     if (get_magic_quotes_gpc()) {
         $title = stripslashes($title);
     }
     $title = Sanitizer::decodeCharReferences($title);
     $title = mb_strtoupper(mb_substr($title, 0, 1)) . mb_substr($title, 1);
     return mysql_real_escape_string(str_replace(' ', '_', $title), $conn);
 }
開發者ID:k-hasan-19,項目名稱:wiki,代碼行數:9,代碼來源:AutoCompleter.php

示例3: newFromText

 /**
  * static constructor, Create new Title from name of page
  */
 public static function newFromText($text, $namespace, $city_id)
 {
     $filteredText = Sanitizer::decodeCharReferences($text);
     $title = new GlobalTitle();
     $title->mText = $filteredText;
     $title->mDbkeyform = str_replace(' ', '_', $filteredText);
     $title->mUrlform = wfUrlencode($title->mDbkeyform);
     $title->mTextform = str_replace('_', ' ', $title->mText);
     $title->mNamespace = $namespace;
     $title->mCityId = $city_id;
     return $title;
 }
開發者ID:schwarer2006,項目名稱:wikia,代碼行數:15,代碼來源:GlobalTitle.php

示例4: escapeFragmentForURL

 /**
  * For compatibility with version < 1.9.0
  */
 static function escapeFragmentForURL($fragment)
 {
     global $mgVersion;
     if ($mgVersion < 10900) {
         $fragment = str_replace(' ', '_', $fragment);
         $fragment = urlencode(Sanitizer::decodeCharReferences($fragment));
         $replaceArray = array('%3A' => ':', '%2F' => '/', '%' => '.');
         return strtr($fragment, $replaceArray);
     } else {
         return Title::escapeFragmentForURL($fragment);
     }
 }
開發者ID:Avalanche85,項目名稱:mw-extensions,代碼行數:15,代碼來源:MultiLanguageManager_body.php

示例5: getResultText

 protected function getResultText(SMWQueryResult $res, $outputmode)
 {
     $result = '';
     if ($outputmode == SMW_OUTPUT_FILE) {
         // make CSV file
         $csv = fopen('php://temp', 'r+');
         if ($this->mShowHeaders) {
             $header_items = array();
             foreach ($res->getPrintRequests() as $pr) {
                 $header_items[] = $pr->getLabel();
             }
             fputcsv($csv, $header_items, $this->m_sep);
         }
         while ($row = $res->getNext()) {
             $row_items = array();
             foreach ($row as $field) {
                 $growing = array();
                 while (($object = $field->getNextDataValue()) !== false) {
                     $growing[] = Sanitizer::decodeCharReferences($object->getWikiValue());
                 }
                 $row_items[] = implode(',', $growing);
             }
             fputcsv($csv, $row_items, $this->m_sep);
         }
         rewind($csv);
         $result .= stream_get_contents($csv);
     } else {
         // just make link to feed
         if ($this->getSearchLabel($outputmode)) {
             $label = $this->getSearchLabel($outputmode);
         } else {
             $label = wfMsgForContent('smw_csv_link');
         }
         $link = $res->getQueryLink($label);
         $link->setParameter('csv', 'format');
         $link->setParameter($this->m_sep, 'sep');
         if (array_key_exists('mainlabel', $this->params) && $this->params['mainlabel'] !== false) {
             $link->setParameter($this->params['mainlabel'], 'mainlabel');
         }
         $link->setParameter($this->mShowHeaders ? 'show' : 'hide', 'headers');
         if (array_key_exists('limit', $this->params)) {
             $link->setParameter($this->params['limit'], 'limit');
         } else {
             // use a reasonable default limit
             $link->setParameter(100, 'limit');
         }
         $result .= $link->getText($outputmode, $this->mLinker);
         $this->isHTML = $outputmode == SMW_OUTPUT_HTML;
         // yes, our code can be viewed as HTML if requested, no more parsing needed
     }
     return $result;
 }
開發者ID:Tjorriemorrie,項目名稱:app,代碼行數:52,代碼來源:SMW_QP_CSV.php

示例6: parseResponse

 protected function parseResponse(TranslationQueryResponse $reply)
 {
     $body = $reply->getBody();
     $response = FormatJson::decode($body);
     if (!is_object($response)) {
         throw new TranslationWebServiceException('Invalid json: ' . serialize($body));
     } elseif ($response->code !== 200) {
         throw new TranslationWebServiceException($response->message);
     }
     $text = Sanitizer::decodeCharReferences($response->text[0]);
     $text = $this->unwrapUntranslatable($text);
     return trim($text);
 }
開發者ID:HuijiWiki,項目名稱:mediawiki-extensions-Translate,代碼行數:13,代碼來源:YandexWebService.php

示例7: getName

 /**
  * Return the original filename of the uploaded file
  *
  * @return string|null Filename or null if non-existent
  */
 public function getName()
 {
     if (!$this->exists()) {
         return null;
     }
     global $wgContLang;
     $name = $this->fileInfo['name'];
     # Safari sends filenames in HTML-encoded Unicode form D...
     # Horrid and evil! Let's try to make some kind of sense of it.
     $name = Sanitizer::decodeCharReferences($name);
     $name = $wgContLang->normalize($name);
     wfDebug(__METHOD__ . ": {$this->fileInfo['name']} normalized to '{$name}'\n");
     return $name;
 }
開發者ID:claudinec,項目名稱:galan-wiki,代碼行數:19,代碼來源:WebRequestUpload.php

示例8: newFromText

 /**
  * @desc Static constructor, Create new Title from name of page
  *
  * @param String $text
  * @param Integer $namespace (default NS_MAIN)
  * @param Integer|null $city_id a wiki id; we allow null because of compatibility with Title::newFromText()
  *
  * @throws Exception when $city_id parameter is null
  *
  * @return GlobalTitle
  */
 public static function newFromText($text, $namespace = NS_MAIN, $city_id = null)
 {
     if ($city_id === null) {
         // we allow to pass null in the method definition because of Strict Compatibility with Title::newFromText()
         throw new \Exception('Invalid $city_id.');
     }
     $filteredText = Sanitizer::decodeCharReferences($text);
     $title = new GlobalTitle();
     $title->mText = $filteredText;
     $title->mDbkeyform = str_replace(' ', '_', $filteredText);
     $title->mUrlform = wfUrlencode($title->mDbkeyform);
     $title->mTextform = str_replace('_', ' ', $title->mText);
     $title->mNamespace = $namespace;
     $title->mCityId = $city_id;
     return $title;
 }
開發者ID:yusufchang,項目名稱:app,代碼行數:27,代碼來源:GlobalTitle.php

示例9: processRow

 protected function processRow($row)
 {
     global $wgContLang;
     $source = $row->img_name;
     // do nothing for videos, regardless of anything else
     if ('VIDEO' == $row->img_media_type && 'video' == $row->img_major_mime && 'swf' == $row->img_minor_mime) {
         $this->log("omitting video row '{$source}'");
         return $this->progress(0);
     }
     if ($source == '') {
         // Ye olde empty rows. Just kill them.
         $this->killRow($source);
         return $this->progress(1);
     }
     $cleaned = $source;
     // About half of old bad image names have percent-codes
     $cleaned = rawurldecode($cleaned);
     // We also have some HTML entities there
     $cleaned = Sanitizer::decodeCharReferences($cleaned);
     // Some are old latin-1
     $cleaned = $wgContLang->checkTitleEncoding($cleaned);
     // Many of remainder look like non-normalized unicode
     $cleaned = $wgContLang->normalize($cleaned);
     $title = Title::makeTitleSafe(NS_FILE, $cleaned);
     if (is_null($title)) {
         $this->output("page {$source} ({$cleaned}) is illegal.\n");
         $safe = $this->buildSafeTitle($cleaned);
         if ($safe === false) {
             return $this->progress(0);
         }
         $this->pokeFile($source, $safe);
         return $this->progress(1);
     }
     if ($title->getDBkey() !== $source) {
         $munged = $title->getDBkey();
         $this->output("page {$source} ({$munged}) doesn't match self.\n");
         $this->pokeFile($source, $munged);
         return $this->progress(1);
     }
     return $this->progress(0);
 }
開發者ID:Tjorriemorrie,項目名稱:app,代碼行數:41,代碼來源:cleanupImages.php

示例10: handleRow

 protected function handleRow($row)
 {
     $template_params = array();
     $field_num = 0;
     foreach ($row as $field) {
         $field_num++;
         $key = $field->getPrintRequest()->getLabel();
         if (empty($key)) {
             $key = $field_num;
         }
         $value = array();
         while (($object = $field->getNextDataValue()) !== false) {
             $value[] = Sanitizer::decodeCharReferences($object->getWikiValue());
         }
         $template_params[$key] = $value;
     }
     if (isset($template_params['To']) && count($template_params['To']) > 0) {
         $data = array('title' => $this->pageTitle, 'params' => $template_params, 'template' => $this->params['template']);
         $row = $this->emailsTable->newRow($data);
         $row->save();
     }
 }
開發者ID:ATCARES,項目名稱:SemanticMailMerge,代碼行數:22,代碼來源:ResultFormat.php

示例11: categoryLinkHook

 static function categoryLinkHook($parser, $holders, $markers, Title $title, $titleText, &$sortText = null, &$leadingColon = false)
 {
     global $wgContLang;
     # When a category link starts with a : treat it as a normal link
     if ($leadingColon) {
         return true;
     }
     if (isset($sortText) && $markers->findMarker($sortText)) {
         # There are links inside of the sortText
         # For backwards compatibility the deepest links are dominant so this
         # link should not be handled
         $sortText = $markers->expand($sortText);
         # Return false so that this link is reverted back to WikiText
         return false;
     }
     if (!isset($sortText)) {
         $sortText = $parser->getDefaultSort();
     }
     $sortText = Sanitizer::decodeCharReferences($sortText);
     $sortText = str_replace("\n", '', $sortText);
     $sortText = $wgContLang->convertCategoryKey($sortText);
     $parser->mOutput->addCategory($title->getDBkey(), $sortText);
     return '';
 }
開發者ID:rocLv,項目名稱:conference,代碼行數:24,代碼來源:CoreLinkFunctions.php

示例12: processPage

 function processPage($row)
 {
     global $wgContLang;
     $source = $row->img_name;
     if ($source == '') {
         // Ye olde empty rows. Just kill them.
         $this->killRow($source);
         return $this->progress(1);
     }
     $cleaned = $source;
     // About half of old bad image names have percent-codes
     $cleaned = rawurldecode($cleaned);
     // We also have some HTML entities there
     $cleaned = Sanitizer::decodeCharReferences($cleaned);
     // Some are old latin-1
     $cleaned = $wgContLang->checkTitleEncoding($cleaned);
     // Many of remainder look like non-normalized unicode
     $cleaned = UtfNormal::cleanUp($cleaned);
     $title = Title::makeTitleSafe(NS_FILE, $cleaned);
     if (is_null($title)) {
         $this->log("page {$source} ({$cleaned}) is illegal.");
         $safe = $this->buildSafeTitle($cleaned);
         if ($safe === false) {
             return $this->progress(0);
         }
         $this->pokeFile($source, $safe);
         return $this->progress(1);
     }
     if ($title->getDBkey() !== $source) {
         $munged = $title->getDBkey();
         $this->log("page {$source} ({$munged}) doesn't match self.");
         $this->pokeFile($source, $munged);
         return $this->progress(1);
     }
     $this->progress(0);
 }
開發者ID:amjadtbssm,項目名稱:website,代碼行數:36,代碼來源:cleanupImages.php

示例13: createFormLink

 static function createFormLink(&$parser, $specialPageName, $params)
 {
     // Set defaults.
     $inFormName = $inLinkStr = $inLinkType = $inTooltip = $inQueryStr = $inTargetName = '';
     if ($specialPageName == 'RunQuery') {
         $inLinkStr = wfMessage('runquery')->text();
     }
     $classStr = "";
     $inQueryArr = array();
     $positionalParameters = false;
     // assign params
     // - support unlabelled params, for backwards compatibility
     // - parse and sanitize all parameter values
     foreach ($params as $i => $param) {
         $elements = explode('=', $param, 2);
         // set param_name and value
         if (count($elements) > 1 && !$positionalParameters) {
             $param_name = trim($elements[0]);
             // parse (and sanitize) parameter values
             $value = trim($parser->recursiveTagParse($elements[1]));
         } else {
             $param_name = null;
             // parse (and sanitize) parameter values
             $value = trim($parser->recursiveTagParse($param));
         }
         if ($param_name == 'form') {
             $inFormName = $value;
         } elseif ($param_name == 'link text') {
             $inLinkStr = $value;
         } elseif ($param_name == 'link type') {
             $inLinkType = $value;
         } elseif ($param_name == 'query string') {
             // Change HTML-encoded ampersands directly to
             // URL-encoded ampersands, so that the string
             // doesn't get split up on the '&'.
             $inQueryStr = str_replace('&amp;', '%26', $value);
             parse_str($inQueryStr, $arr);
             $inQueryArr = self::array_merge_recursive_distinct($inQueryArr, $arr);
         } elseif ($param_name == 'tooltip') {
             $inTooltip = Sanitizer::decodeCharReferences($value);
         } elseif ($param_name == 'target') {
             $inTargetName = $value;
         } elseif ($param_name == null && $value == 'popup') {
             self::loadScriptsForPopupForm($parser);
             $classStr = 'popupformlink';
         } elseif ($param_name !== null && !$positionalParameters) {
             $value = urlencode($value);
             parse_str("{$param_name}={$value}", $arr);
             $inQueryArr = self::array_merge_recursive_distinct($inQueryArr, $arr);
         } elseif ($i == 0) {
             $inFormName = $value;
             $positionalParameters = true;
         } elseif ($i == 1) {
             $inLinkStr = $value;
         } elseif ($i == 2) {
             $inLinkType = $value;
         } elseif ($i == 3) {
             // Change HTML-encoded ampersands directly to
             // URL-encoded ampersands, so that the string
             // doesn't get split up on the '&'.
             $inQueryStr = str_replace('&amp;', '%26', $value);
             parse_str($inQueryStr, $arr);
             $inQueryArr = self::array_merge_recursive_distinct($inQueryArr, $arr);
         }
     }
     $ad = SFUtils::getSpecialPage($specialPageName);
     $link_url = $ad->getTitle()->getLocalURL() . "/{$inFormName}";
     if (!empty($inTargetName)) {
         $link_url .= "/{$inTargetName}";
     }
     $link_url = str_replace(' ', '_', $link_url);
     $hidden_inputs = "";
     if (!empty($inQueryArr)) {
         // Special handling for the buttons - query string
         // has to be turned into hidden inputs.
         if ($inLinkType == 'button' || $inLinkType == 'post button') {
             $query_components = explode('&', http_build_query($inQueryArr, '', '&'));
             foreach ($query_components as $query_component) {
                 $var_and_val = explode('=', $query_component, 2);
                 if (count($var_and_val) == 2) {
                     $hidden_inputs .= Html::hidden(urldecode($var_and_val[0]), urldecode($var_and_val[1]));
                 }
             }
         } else {
             $link_url .= strstr($link_url, '?') ? '&' : '?';
             $link_url .= str_replace('+', '%20', http_build_query($inQueryArr, '', '&'));
         }
     }
     if ($inLinkType == 'button' || $inLinkType == 'post button') {
         $formMethod = $inLinkType == 'button' ? 'get' : 'post';
         $str = Html::rawElement('form', array('action' => $link_url, 'method' => $formMethod, 'class' => $classStr), '<button ' . Html::expandAttributes(array('type' => 'submit', 'value' => $inLinkStr)) . '>' . $inLinkStr . '</button>' . $hidden_inputs);
     } else {
         // If a target page has been specified but it doesn't
         // exist, make it a red link.
         if (!empty($inTargetName)) {
             $targetTitle = Title::newFromText($inTargetName);
             if (is_null($targetTitle) || !$targetTitle->exists()) {
                 $classStr .= " new";
             }
         }
//.........這裏部分代碼省略.........
開發者ID:seedbank,項目名稱:old-repo,代碼行數:101,代碼來源:SF_Utils.php

示例14: guessSectionNameFromWikiText

 /**
  * Try to guess the section anchor name based on a wikitext fragment
  * presumably extracted from a heading, for example "Header" from
  * "== Header ==".
  */
 public function guessSectionNameFromWikiText($text)
 {
     # Strip out wikitext links(they break the anchor)
     $text = $this->stripSectionName($text);
     $headline = Sanitizer::decodeCharReferences($text);
     # strip out HTML
     $headline = StringUtils::delimiterReplace('<', '>', '', $headline);
     $headline = trim($headline);
     $sectionanchor = '#' . urlencode(str_replace(' ', '_', $headline));
     $replacearray = array('%3A' => ':', '%' => '.');
     return str_replace(array_keys($replacearray), array_values($replacearray), $sectionanchor);
 }
開發者ID:josephdye,項目名稱:wikireader,代碼行數:17,代碼來源:Parser.php

示例15: escapeFragmentForURL

 /**
  * Escape a text fragment, say from a link, for a URL
  */
 static function escapeFragmentForURL($fragment)
 {
     $fragment = str_replace(' ', '_', $fragment);
     $fragment = urlencode(Sanitizer::decodeCharReferences($fragment));
     $replaceArray = array('%3A' => ':', '%' => '.');
     return strtr($fragment, $replaceArray);
 }
開發者ID:arlendotcn,項目名稱:ilias,代碼行數:10,代碼來源:Title.php


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