最近在对前端表单输入数据进行处理中,遇到几个php字符串处理函数,真心搞不懂作用是什么,api说的太过于模糊,看不太懂,求大神帮忙解答一下区别和作用:
htmlspecialchars
addslashes
stripslashes
strip_tags
立即学习“PHP免费学习笔记(深入)”;
nl2br
mysql_real_escape_string
我就是想将textarea里的数据insert into进mysql数据库,用户可能输入html等乱七八糟的字符串,插入mysql,我应该怎么处理?
最近在对前端表单输入数据进行处理中,遇到几个php字符串处理函数,真心搞不懂作用是什么,api说的太过于模糊,看不太懂,求大神帮忙解答一下区别和作用:
htmlspecialchars
addslashes
stripslashes
strip_tags
立即学习“PHP免费学习笔记(深入)”;
nl2br
mysql_real_escape_string
我就是想将textarea里的数据insert into进mysql数据库,用户可能输入html等乱七八糟的字符串,插入mysql,我应该怎么处理?
标准写法(请忘掉那一堆乱七八糟的函数):
//检查防止SQL注入的函数
function MySQLCheck(&$value)
{
//去除斜杠(服务器配置给予的转义斜杠)
if (get_magic_quotes_gpc())
{
$value = stripslashes($value);
}
//如果不是数字则加引号(专业的转义函数)
if (!is_numeric($value))
{
$value = "'" . mysql_real_escape_string($value) . "'";
}
return $value;
//示例用法:
//$user = SQLCheck($_POST['user']);
//$pwd = SQLCheck($_POST['pwd']);
//$sql = "SELECT * FROM users WHERE user = $user AND password = $pwd";
}
函数来源(开源库):https://github.com/MoonLord-LM/MyPHP
另外,新版PHP已经废弃mysql扩展,推荐用mysqli扩展了,代码如下:
//检查防止SQL注入的函数
function MySQLCheck(&$value)
{
global $Connect;
//去除斜杠(服务器配置给予的转义斜杠)
if (get_magic_quotes_gpc())
{
$value = stripslashes($value);
}
//如果不是数字则加引号(专业的转义函数)
if (!is_numeric($value))
{
$value = "'" . mysqli_real_escape_string($Connect,$value) . "'";
}
return $value;
//示例用法:
//$user = SQLCheck($_POST['user']);
//$pwd = SQLCheck($_POST['pwd']);
//$sql = "SELECT * FROM users WHERE user = $user AND password = $pwd";
}
上面的$Connect是数据库连接。
注意,这两个函数都是要在连接了MySQL数据库之后才能执行,否则会有报错。
另外,前端如果要展示,那么也要对script等等标签进行处理,可以用PHP的str_replace函数进行替换,还有
PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号