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

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的作用是把:

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



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


一般来说使用 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() 例子

输出:
Escaped string: Zak\'s Laptop
mysql_real_escape_string() 函数

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

下列字符受影响:

  • \x00
  • \n
  • \r
  • \
  • '
  • "
  • \x1a

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

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


那么 SQL 查询会成为这样:
SELECT * FROM users
WHERE user='john' AND password='' OR ''=''
这意味着任何用户无需输入合法的密码即可登陆。
预防数据库攻击的正确做法:

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






你可能感兴趣的:(php学习,html收藏,mysql)