zoukankan      html  css  js  c++  java
  • 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;

    }

  • 相关阅读:
    Java解析复杂xml文件,使用Xpath
    表达式求值
    解决 error CS0012 错误
    mssql sqlserver 分组排序函数row_number、rank、dense_rank用法简介及说明
    c#核心基础
    Git源代码管理
    CASE 表达式
    NPM -- 初探--01
    ASP.NET Zero--基础设施
    ASP.NET Zero--基于令牌的认证&SWAGGER UI
  • 原文地址:https://www.cnblogs.com/hupengyin/p/5037324.html
Copyright © 2011-2022 走看看