<input type=name value='this's a apple' />
后台处理
$name=addslashes($_POST['name']);//转义单引号insert的时候,是不是带着转义符号一起存到数据库里?还是去掉转义符号存进去?如果是带着转义符号存入到数据库,这就出现了一个小问题如果我要查义name是不是重复,就需要对$name进行比较依然进行转义 $name=addslashes($_POST['name']);SELECT count(*) AS num FROM talbe WHERE name = $namenum显示的是0,也就是说找不到相同的,打印sql语句为 SELECT count(*) AS num FROM talbe WHERE name = 'this/'s a apple'num的值为零,我打开数据库发现,name这个字段的值是 this/'s a apple,这样肯定不能找到如果将$name,再转义一次才能找到,$name的值就是 this///'s a apple 才能找到纪录也就是说用两次addslashes函数请问大家是如何处理这样的问题?如果要用两次不是很麻烦吗?
后台处理
$name=addslashes($_POST['name']);//转义单引号insert的时候,是不是带着转义符号一起存到数据库里?还是去掉转义符号存进去?如果是带着转义符号存入到数据库,这就出现了一个小问题如果我要查义name是不是重复,就需要对$name进行比较依然进行转义 $name=addslashes($_POST['name']);SELECT count(*) AS num FROM talbe WHERE name = $namenum显示的是0,也就是说找不到相同的,打印sql语句为 SELECT count(*) AS num FROM talbe WHERE name = 'this/'s a apple'num的值为零,我打开数据库发现,name这个字段的值是 this/'s a apple,这样肯定不能找到如果将$name,再转义一次才能找到,$name的值就是 this///'s a apple 才能找到纪录也就是说用两次addslashes函数请问大家是如何处理这样的问题?如果要用两次不是很麻烦吗?
改成下面这样
<input name="thisName1" id="thisName1" type=text value="'this's a apple'" />//用个判断
if (!get_magic_quotes_gpc()) {
$lastname = addslashes($_POST['thisName1']);
} else {
$lastname = $_POST['thisName1'];
}magic_quotes_gpc//魔术引用发生作用是在传递$_GET,$_POST,$_COOKIE时,这个在php.ini中设置.有以下两种情况1. 对于magic_quotes_gpc=on的情况,
我们可以不对输入和输出数据库的字符串数据作
addslashes()和stripslashes()的操作,数据也会正常显示。如果此时你对输入的数据作了addslashes()处理,
那么在输出的时候就必须使用stripslashes()去掉多余的反斜杠。2. 对于magic_quotes_gpc=off 的情况
必须使用addslashes()对输入数据进行处理,但并不需要使用stripslashes()格式化输出
因为addslashes()并未将反斜杠一起写入数据库,只是帮助mysql完成了sql语句的执行参考 这两个地方 php中magic_quotes_gpc的作用 PHP magic_quotes_gpc的正确处理方式
也就是说,直接将传入的数据入库的话,是不需要在做转义(addslashes)处理的如果你还需要对传入的数据作进一步加工,或是入库时还有非传入的字符串介入
那么你应该在接收传入数据的地方做去转义(stripslashes)处理
然后在入库前统一做转移处理
如果你给它addslashes了,那就变态了,因为\也会影响mysql解析命令,所以addslashes也会转移它,结果就真的变态了:addslashes("li\'lei");将生成li\\\'lei, 拼成sql:select * from table where name='li\\\'lei',入库后实际就是li\'lei,多了一个\。
再另外,stripslashes很少使用,因为一般只有php.ini默认开启了magic_quotes_gpc(get,post,cookie的意思)的情况下,如果我们希望使用到用户真正提交的值,比如li'lei,那么需要做stripslashes($_POST['name']); 而这里的name是被自动addslahes过的li\'lei, strip后就是li'lei了。
如果不strip,那么输出到页面上,用户看到的会是li\'lei。
不需要,都说了入库不会有\了,那是转义给mysql看的。