php过虑html标签,php过滤html标签

发布时间:2022-11-23

本文目录一览:

  1. php如何过滤编辑器的html标签?
  2. 用php过滤html部分标签
  3. php如何过滤html标签,使用什么函数?
  4. PHP如何去除HTML标签

php如何过滤编辑器的html标签?

选择1. 将特殊符号进行转换,可以用 htmlspecialchars 把变为 "" 等。 选择2. 用正则表达式替换,将标签都删除:

$content = preg_replace('/<.+?>/', '', $content);

用php过滤html部分标签

$str = preg_replace("/\s+/", " ", $str); // 过滤多余回车
$str = preg_replace("/[ ]+/si", "", $str); // 过滤__(""号后面带空格)
$str = preg_replace("/<!--.*?-->/si", "", $str); // 注释
$str = preg_replace("/<!.*?>/si", "", $str); // 过滤DOCTYPE
$str = preg_replace("/(<\/?html.*?>)/si", "", $str); // 过滤html标签
$str = preg_replace("/(<\/?head.*?>)/si", "", $str); // 过滤head标签
$str = preg_replace("/(<\/?meta.*?>)/si", "", $str); // 过滤meta标签
$str = preg_replace("/(<\/?body.*?>)/si", "", $str); // 过滤body标签
$str = preg_replace("/(<\/?link.*?>)/si", "", $str); // 过滤link标签
$str = preg_replace("/(<\/?form.*?>)/si", "", $str); // 过滤form标签
$str = preg_replace("/cookie/si", "COOKIE", $str); // 过滤COOKIE标签
$str = preg_replace("/<applet.*?>(.*?)<\/applet.*?>/si", "", $str); // 过滤applet标签
$str = preg_replace("/(<\/?applet.*?>)/si", "", $str); // 过滤applet标签
$str = preg_replace("/<style.*?>(.*?)<\/style.*?>/si", "", $str); // 过滤style标签
$str = preg_replace("/(<\/?style.*?>)/si", "", $str); // 过滤style标签
$str = preg_replace("/<title.*?>(.*?)<\/title.*?>/si", "", $str); // 过滤title标签
$str = preg_replace("/(<\/?title.*?>)/si", "", $str); // 过滤title标签
$str = preg_replace("/<object.*?>(.*?)<\/object.*?>/si", "", $str); // 过滤object标签
$str = preg_replace("/(<\/?object.*?>)/si", "", $str); // 过滤object标签
$str = preg_replace("/<noframes.*?>(.*?)<\/noframes.*?>/si", "", $str); // 过滤noframes标签
$str = preg_replace("/(<\/?noframes.*?>)/si", "", $str); // 过滤noframes标签
$str = preg_replace("/<i?frame.*?>(.*?)<\/i?frame.*?>/si", "", $str); // 过滤frame标签
$str = preg_replace("/(<\/?i?frame.*?>)/si", "", $str); // 过滤frame标签
$str = preg_replace("/<script.*?>(.*?)<\/script.*?>/si", "", $str); // 过滤script标签
$str = preg_replace("/(<\/?script.*?>)/si", "", $str); // 过滤script标签
$str = preg_replace("/javascript/si", "Javascript", $str); // 过滤script标签
$str = preg_replace("/vbscript/si", "Vbscript", $str); // 过滤script标签
$str = preg_replace("/on([a-z]+)\s*=/si", "On\\1=", $str); // 过滤script标签
$str = preg_replace("/<script/si", "#", $str); // 过滤script标签,如javAsCript:alert(

清除空格,换行

function DeleteHtml($str)
{
    $str = trim($str);
    $str = strip_tags($str, "");
    $str = ereg_replace("\t", "", $str);
    $str = ereg_replace("\r\n", "", $str);
    $str = ereg_replace("\r", "", $str);
    $str = ereg_replace("\n", "", $str);
    $str = ereg_replace(" ", " ", $str);
    return trim($str);
}

过滤HTML属性

  1. 过滤所有 html 标签的正则表达式:
/<[^>]+>/
  1. 过滤所有 html 标签的属性的正则表达式:
$html = preg_replace("/([a-zA-Z]+)[^>]*>/", "\\1>", $html);
  1. 过滤部分 html 标签的正则表达式的排除式(比如排除 p,即不过滤 p):
/<\/?[^pP]+>/
  1. 过滤部分 html 标签的正则表达式的枚举式(比如需要过滤 a、p、b 等):
/<\/?[aApPbB][^>]*>/
  1. 过滤部分 html 标签的属性的正则表达式的排除式(比如排除 alt 属性,即不过滤 alt 属性):
\s(?!alt)[a-zA-Z]+=[^\s]*
  1. 过滤部分 html 标签的属性的正则表达式的枚举式(比如 alt 属性):
(\s)alt=[^\s]*

php如何过滤html标签,使用什么函数?

strip_tags — 从字符串中去除 HTML 和 PHP 标记。

语法:

string strip_tags ( string $str [, string $allowable_tags ] )

该函数返回给定的字符串 str 去除空字符、HTML 和 PHP 标记后的结果。

参数:

  • str:要去除的字符串。
  • allowable_tags:可选参数,指定不被去除的字符列表。

示例:

$str = '<a href="" title="">测试</a>';
echo strip_tags($str);

结果:

测试

PHP如何去除HTML标签

PHP 中有个 strip_tags 函数可以方便地去除 HTML 标签。

echo strip_tags("Hello <b>World</b>"); // 去除 HTML、XML 以及 PHP 的标签。

对于非标准的 HTML 代码也能正确去除。