strip_tags去掉HTML標簽失敗


現在有這樣一個需求:

編輯器里面可以插入圖片,添加新聞的內容,現在要從新聞的內容中截取一部分的文字,作為該篇新聞的描述,怎樣做簡單?

思路:

先用strip_tags函數去掉HTML標簽,然后用 msubstr(這個函數不是TP自帶的,需要手動加上)函數截取字符串

問題:

strip_tags函數去掉HTML標簽,失敗

解決辦法:

先用htmlspecialchars_decode($news_content)把一些預定義的 HTML 實體轉換為字符,然后msubstr($str)

$news_content=htmlspecialchars_decode($news_content);

$news_content=msubstr($news_content);

msubstr函數:

function msubstr($str, $start=0, $length, $charset="utf-8", $suffix=true)

{
if(function_exists("mb_substr")){

if($suffix)

return mb_substr($str, $start, $length, $charset)."...";

else

return mb_substr($str, $start, $length, $charset);

}

elseif(function_exists('iconv_substr')) {

if($suffix)

return iconv_substr($str,$start,$length,$charset)."...";

else

return iconv_substr($str,$start,$length,$charset);

}

$re['utf-8'] = "/[x01-x7f]|[xc2-xdf][x80-xbf]|[xe0-xef]
[x80-xbf]{2}|[xf0-xff][x80-xbf]{3}/";

$re['gb2312'] = "/[x01-x7f]|[xb0-xf7][xa0-xfe]/";

$re['gbk'] = "/[x01-x7f]|[x81-xfe][x40-xfe]/";

$re['big5'] = "/[x01-x7f]|[x81-xfe]([x40-x7e]|xa1-xfe])/";

preg_match_all($re[$charset], $str, $match);

$slice = join("",array_slice($match[0], $start, $length));

if($suffix) return $slice."…";

return $slice;

}

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM