格式化html代码的函数有哪些

来源:互联网 时间:1970-01-01


htmlspecialchars ()
htmlspecialchars() 函数把一些预定义的字符转换为 HTML 实体。语法为:htmlspecialchars(string,quotestyle,character-set).
PHP 从 5.4.0 版本开始把htmlspecialchars() 函数的第三个参数字符串编码的默认值改成了 UTF-8,为了使 PHP 5.4 之前环境中编写的代码能够向前兼容,建议调用 htmlspecialchars 函数的的时候都提供字符串编码参数。比如说PHP代码中的中文编码正好是 GB2312 编码,那么就得htmlspecialchars(string, quotestyle ,'GB2312');
这个函数是过滤 ' "" 即 单引号 双引号的


在入库的时候如果不过滤 ' ""这样的东西 php程序员应该能明白有多可怕


htmlspecialchars的作用是把:

预定义的字符是:&(和号) 成为&amp;" (双引号) 成为 &quot;' (单引号) 成为 '< (小于) 成为 &lt;> (大于) 成为 &gt;


输出的时候不需要特殊处理 浏览器 会把这些标签还原的 


一般来说使用 mysql_escape_string() 处理sql语句就可以解决很多问题 
htmlentities 

htmlentities却会转化所有的html代码,连同里面的它无法识别的中文字符也给转化了。 
有中文的时候,最好用 htmlspecialchars ,否则可能乱码 
htmlspecialchar()函数和htmlentities()函数类似都是把html代码转换,htmlspecialchars_decode是把转化的html的编码转换成转换回来。
mysql_escape_string
(PHP 4 >= 4.0.3, PHP 5, 注意:在PHP5.3中已经弃用这种方法,不推荐使用)
mysql_escape_string -- 转义一个字符串用于 mysql_query

例子 1. mysql_escape_string() 例子<?php$item = "Zak's Laptop";$escaped_item = mysql_escape_string($item);printf ("Escaped string: %s/n", $escaped_item);?>输出:Escaped string: Zak/'s Laptop
mysql_real_escape_string() 函数

mysql_real_escape_string() 函数转义 SQL 语句中使用的字符串中的特殊字符。

下列字符受影响:

  • /x00
  • /n
  • /r
  • /
  • '
  • "
  • /x1a

如果成功,则该函数返回被转义的字符串。如果失败,则返回 false。

数据库攻击。本例演示如果我们不对用户名和密码应用 mysql_real_escape_string() 函数会发生什么:

<?php$con = mysql_connect("localhost", "hello", "321");if (!$con) { die('Could not connect: ' . mysql_error()); }$sql = "SELECT * FROM usersWHERE user='{$_POST['user']}'AND password='{$_POST['pwd']}'";mysql_query($sql);// 不检查用户名和密码// 可以是用户输入的任何内容,比如:$_POST['user'] = 'john';$_POST['pwd'] = "' OR ''='";// 一些代码...mysql_close($con);?>

那么 SQL 查询会成为这样:
SELECT * FROM usersWHERE user='john' AND password='' OR ''=''
这意味着任何用户无需输入合法的密码即可登陆。预防数据库攻击的正确做法:
<?phpfunction check_input($value){// 去除斜杠if (get_magic_quotes_gpc()) { $value = stripslashes($value); }// 如果不是数字则加引号if (!is_numeric($value)) { $value = "'" . mysql_real_escape_string($value) . "'"; }return $value;}$con = mysql_connect("localhost", "hello", "321");if (!$con) { die('Could not connect: ' . mysql_error()); }// 进行安全的 SQL$user = check_input($_POST['user']);$pwd = check_input($_POST['pwd']);$sql = "SELECT * FROM users WHEREuser=$user AND password=$pwd";mysql_query($sql);mysql_close($con);?>

如果还有会继续添加谢谢大家提出意见







相关阅读:
Top