欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

PHP實(shí)現(xiàn)網(wǎng)頁(yè)內(nèi)容html標(biāo)簽補(bǔ)全和過濾的方法小結(jié)【2種方法】

 更新時(shí)間:2017年04月27日 10:58:53   作者:websites  
這篇文章主要介紹了PHP實(shí)現(xiàn)網(wǎng)頁(yè)內(nèi)容html標(biāo)簽補(bǔ)全和過濾的方法,結(jié)合實(shí)例形式分析了php常見的標(biāo)簽檢查、補(bǔ)全、閉合、過濾等相關(guān)操作技巧,需要的朋友可以參考下

本文實(shí)例講述了PHP實(shí)現(xiàn)網(wǎng)頁(yè)內(nèi)容html標(biāo)簽補(bǔ)全和過濾的方法。分享給大家供大家參考,具體如下:

如果你的網(wǎng)頁(yè)內(nèi)容的html標(biāo)簽顯示不全,有些表格標(biāo)簽不完整而導(dǎo)致頁(yè)面混亂,或者把你的內(nèi)容之外的局部html頁(yè)面給包含進(jìn)去了,我們可以寫個(gè)函數(shù)方法來補(bǔ)全html標(biāo)簽以及過濾掉無用的html標(biāo)簽.

php使HTML標(biāo)簽自動(dòng)補(bǔ)全,閉合,過濾函數(shù)方法一:

代碼:

function closetags($html) {
 preg_match_all('#<(?!meta|img|br|hr|input\b)\b([a-z]+)(?: .*)?(?<![/|/ ])>#iU', $html, $result);
 $openedtags = $result[1];
 preg_match_all('#</([a-z]+)>#iU', $html, $result);
 $closedtags = $result[1];
 $len_opened = count($openedtags);
 if (count($closedtags) == $len_opened) {
    return $html;
 }
 $openedtags = array_reverse($openedtags);
 for ($i=0; $i < $len_opened; $i++) {
    if (!in_array($openedtags[$i], $closedtags)) {
     $html .= '</'.$openedtags[$i].'>';
    }else {
     unset($closedtags[array_search($openedtags[$i], $closedtags)]);
    }
 }
 return $html;
}

closetags()解析:

array_reverse() : 此函數(shù)將原數(shù)組中的元素順序翻轉(zhuǎn),創(chuàng)建新的數(shù)組并返回。如果第二個(gè)參數(shù)指定為 true,則元素的鍵名保持不變,否則鍵名將丟失。

array_search() : array_search(value,array,strict),此函數(shù)與in_array()一樣在數(shù)組中查找一個(gè)鍵值。如果找到了該值,匹配元素的鍵名會(huì)被返回。如果沒找到,則返回 false。 如果第三個(gè)參數(shù)strict被指定為 true,則只有在數(shù)據(jù)類型和值都一致時(shí)才返回相應(yīng)元素的鍵名。

php使HTML標(biāo)簽自動(dòng)補(bǔ)全,閉合,過濾函數(shù)方法二:

function checkhtml($html) {
  $html = stripslashes($html);
    preg_match_all("/\<([^\<]+)\>/is", $html, $ms);
    $searchs[] = '<';
    $replaces[] = '<';
    $searchs[] = '>';
    $replaces[] = '>';
    if($ms[1]) {
      $allowtags = 'img|font|div|table|tbody|tr|td|th|br|p|b|strong|i|u|em|span|ol|ul|li';//允許的標(biāo)簽
      $ms[1] = array_unique($ms[1]);
      foreach ($ms[1] as $value) {
        $searchs[] = "<".$value.">";
        $value = shtmlspecialchars($value);
        $value = str_replace(array('\\','/*'), array('.','/.'), $value);
        $value = preg_replace(array("/(javascript|script|eval|behaviour|expression)/i", "/(\s+|"|')on/i"), array('.', ' .'), $value);
        if(!preg_match("/^[\/|\s]?($allowtags)(\s+|$)/is", $value)) {
          $value = '';
        }
        $replaces[] = empty($value)?'':"<".str_replace('"', '"', $value).">";
      }
    }
    $html = str_replace($searchs, $replaces, $html);
  return $html;
}
//取消HTML代碼
function shtmlspecialchars($string) {
  if(is_array($string)) {
    foreach($string as $key => $val) {
      $string[$key] = shtmlspecialchars($val);
    }
  } else {
    $string = preg_replace('/&((#(\d{3,5}|x[a-fA-F0-9]{4})|[a-zA-Z][a-z0-9]{2,5});)/', '&\\1',
      str_replace(array('&', '"', '<', '>'), array('&', '"', '<', '>'), $string));
  }
  return $string;
}

checkhtml($html)解析:

stripslashes():函數(shù)刪除由addslashes()函數(shù)添加的反斜杠。該函數(shù)用于清理從數(shù)據(jù)庫(kù)或HTML表單中取回的數(shù)據(jù)。

更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《PHP數(shù)據(jù)結(jié)構(gòu)與算法教程》、《php程序設(shè)計(jì)算法總結(jié)》、《php排序算法總結(jié)》、《PHP常用遍歷算法與技巧總結(jié)》、《PHP數(shù)學(xué)運(yùn)算技巧總結(jié)》、《PHP數(shù)組(Array)操作技巧大全》、《php字符串(string)用法總結(jié)》及《php常見數(shù)據(jù)庫(kù)操作技巧匯總

希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。

相關(guān)文章

  • ubuntu下編譯安裝xcache for php5.3 的具體操作步驟

    ubuntu下編譯安裝xcache for php5.3 的具體操作步驟

    本篇文章是對(duì)ubuntu下編譯安裝xcache for php5.3的操作進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-06-06
  • PHP生成RSS文件類實(shí)例

    PHP生成RSS文件類實(shí)例

    這篇文章主要介紹了PHP生成RSS文件類,可實(shí)現(xiàn)PHP生成RSS文件的功能,對(duì)于網(wǎng)站建設(shè)與優(yōu)化來說具有一定的實(shí)用價(jià)值,需要的朋友可以參考下
    2014-12-12
  • php 地區(qū)分類排序算法

    php 地區(qū)分類排序算法

    本篇文章是對(duì)使用php實(shí)現(xiàn)地區(qū)分類排序算法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-07-07
  • 調(diào)試一段PHP程序時(shí)遇到的三個(gè)問題

    調(diào)試一段PHP程序時(shí)遇到的三個(gè)問題

    調(diào)試一段PHP程序時(shí)遇到的三個(gè)問題,學(xué)習(xí)php的朋友可以參考下。
    2012-01-01
  • php設(shè)計(jì)模式 Singleton(單例模式)

    php設(shè)計(jì)模式 Singleton(單例模式)

    保證一個(gè)類僅有一個(gè)實(shí)例,并提供一個(gè)訪問它的全局訪問點(diǎn)
    2011-06-06
  • 最新評(píng)論