$string = preg_replace('/&((#(\d{3,5}|x[a-fA-F0-9]{4}));)/', '&\\1',
str_replace(array('&', '"', '<', '>'), array('&amp;', '&quot;', '&lt;', '&gt;'), $string));转义字符串中的特殊字符 '/&amp;((#(\d{3,5}|x[a-fA-F0-9]{4}));)/', '&\\1', 这部分含义?

解决方案 »

  1.   

    拆开理解就是了
    然后把&amp;#nnnnn 或 &amp;#xnnnn 换成 &#nnnnn\\1表示对第一个括号内的内容原样保留,就是((#(\d{3,5}|x[a-fA-F0-9]{4}))这部分
      

  2.   


    这个是DISCUZ 的过滤函数对吧。
    其实这个函数的意识就是过滤 HTML字符串,但是那些已经被过滤了的,比如“'"”单引号双引号。“&”的实体是&amp;那么像这样的就不过滤,保留,以防多次过滤。结果 &amp;变成了&ampamp;
    //取消HTML代码
    function shtmlspecialchars($string) {
    if(is_array($string)) {
    foreach($string as $key => $val) {
    $string[$key] = shtmlspecialchars($val);
    }
    } else{
    $string = preg_replace('/&amp;((#(\d{3,5}|x[a-fA-F0-9]{4})|[a-zA-Z][a-z0-9]{1,5});)/', '&\\1',
    str_replace(array('&', '"', '<', '>','\''), array('&amp;', '&quot;', '&lt;', '&gt;','&#039;'), $string));
    }
    return $string;
    }