还有啊。如果在单引号里面:\ 和 \\ 经过addslashes()后,都会转成相同的2个反斜杠:\\.

解决方案 »

  1.   

    2楼,显然没有明白我的意思。
    addslashes是对特定的转义字符进行转义的。
    单引号内仅支持2个:\\, \"
    但实际上对\'也支持,你仔细看下我的测试结果。
      

  2.   

    你先要明白为什么会有转义一说
    当用单引号括起的字符串中有单引号时,如 'ab'c'
    当用双引号括起的字符串中有双引号时,如 "ab"c"
    你说这个字符串是到 b 就结束了,还是要到 c 才结束呢?
    弄不清了吧?这就是因为'(")二义性造成了歧义
    于是为了解决这个歧义,引入了转义的概念。而字符\一般不会出现在正文中,所以就用它作为转义符
    'ab\'c'、"ab\"c" 中 \'、\" 使得引号失去引号的含义,而只被当做普通的字符
    \r、 \n、\t 使得字母r、n、t失去了其字母的含义,而被当做 ascii 码的 回车、换行、制表符虽然 \ 在正文里很少出现,但还是有可能出现的。所以就用 \\ 来使 \ 失去转义的作用
      

  3.   

    string addslashes ( string str )
    返回字符串,该字符串为了数据库查询语句等的需要在某些字符前加上了反斜线。这些字符是单引号(')、双引号(")、反斜线(\)与 NUL(NULL 字符)。 
      

  4.   

    转义过的字符串使用 addslashes(),因为这样会导致双层转义,
    遇到这种情况时可以使用函数 get_magic_quotes_gpc() 进行检测。
      

  5.   

    经过调试,5楼正解:
    addslashes()针对你所说的4种字符进行转义。
    这里有两个易混淆问题:
    一个是addslashes()函数针对的转义字符。(就是5楼所说的)
    另一个是单引号及双引号内字串的转义字符(楼顶说过了)
    恕本人愚钝,现在才分清。多谢兄弟们帮助。
      

  6.   

    哈哈,单引号里面有一个\,或者两个\,经过addslashes()后,都是两个\\,不知道这算不算bug?
    $single_quote_str ='1个反斜杠:\; 2个反斜杠:\\';
    显示字串=1个反斜杠:\; 2个反斜杠:\ 
    转义字串=1个反斜杠:\\; 2个反斜杠:\\ 
    还原字串=1个反斜杠:\; 2个反斜杠:\