Sophie

Sophie

distrib > Mandriva > 2008.1 > x86_64 > by-pkgid > 05cd670d8a02b2b4a0ffb1756f2e8308 > files > 112

php-manual-zh-5.2.4-1mdv2008.1.noarch.rpm

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<HTML
><HEAD
><TITLE
>addslashes</TITLE
><META
NAME="GENERATOR"
CONTENT="Modular DocBook HTML Stylesheet Version 1.79"><LINK
REL="HOME"
TITLE="PHP 手册"
HREF="index.html"><LINK
REL="UP"
TITLE="String 字符串处理函数"
HREF="ref.strings.html"><LINK
REL="PREVIOUS"
TITLE="addcslashes"
HREF="function.addcslashes.html"><LINK
REL="NEXT"
TITLE="bin2hex"
HREF="function.bin2hex.html"><META
HTTP-EQUIV="Content-type"
CONTENT="text/html; charset=UTF-8"></HEAD
><BODY
CLASS="refentry"
BGCOLOR="#FFFFFF"
TEXT="#000000"
LINK="#0000FF"
VLINK="#840084"
ALINK="#0000FF"
><DIV
CLASS="NAVHEADER"
><TABLE
SUMMARY="Header navigation table"
WIDTH="100%"
BORDER="0"
CELLPADDING="0"
CELLSPACING="0"
><TR
><TH
COLSPAN="3"
ALIGN="center"
>PHP 手册</TH
></TR
><TR
><TD
WIDTH="10%"
ALIGN="left"
VALIGN="bottom"
><A
HREF="function.addcslashes.html"
ACCESSKEY="P"
>上一页</A
></TD
><TD
WIDTH="80%"
ALIGN="center"
VALIGN="bottom"
></TD
><TD
WIDTH="10%"
ALIGN="right"
VALIGN="bottom"
><A
HREF="function.bin2hex.html"
ACCESSKEY="N"
>下一页</A
></TD
></TR
></TABLE
><HR
ALIGN="LEFT"
WIDTH="100%"></DIV
><H1
><A
NAME="function.addslashes"
></A
>addslashes</H1
><DIV
CLASS="refnamediv"
><A
NAME="AEN224550"
></A
><P
>    (PHP 3, PHP 4, PHP 5)</P
>addslashes&nbsp;--&nbsp;使用反斜线引用字符串</DIV
><DIV
CLASS="refsect1"
><A
NAME="AEN224553"
></A
><H2
>说明</H2
>string <B
CLASS="methodname"
>addslashes</B
> ( string str )<BR
></BR
><P
>&#13;   返回字符串,该字符串为了数据库查询语句等的需要在某些字符前加上了反斜线。这些字符是单引号(<TT
CLASS="literal"
>'</TT
>)、双引号(<TT
CLASS="literal"
>"</TT
>)、反斜线(<TT
CLASS="literal"
>\</TT
>)与
   NUL(<TT
CLASS="constant"
><B
>NULL</B
></TT
> 字符)。
  </P
><P
>&#13;   一个使用 <B
CLASS="function"
>addslashes()</B
>
   的例子是当你要往数据库中输入数据时。例如,将名字
   <TT
CLASS="literal"
>O'reilly</TT
> 插入到数据库中,这就需要对其进行转义。大多数据库使用
   <TT
CLASS="literal"
>\</TT
> 作为转义符:<TT
CLASS="literal"
>O\'reilly</TT
>。这样可以将数据放入数据库中,而不会插入额外的
   <TT
CLASS="literal"
>\</TT
>。当 PHP
   指令 <A
HREF="ref.sybase.html#ini.magic-quotes-sybase"
>magic_quotes_sybase</A
>
   被设置成 <TT
CLASS="literal"
>on</TT
> 时,意味着插入
   <TT
CLASS="literal"
>'</TT
> 时将使用
   <TT
CLASS="literal"
>'</TT
> 进行转义。
  </P
><P
>&#13;   默认情况下,PHP 指令 <A
HREF="ref.info.html#ini.magic-quotes-gpc"
>magic_quotes_gpc</A
>
   为 <TT
CLASS="literal"
>on</TT
>,它主要是对所有的
   GET、POST 和 COOKIE 数据自动运行
   <B
CLASS="function"
>addslashes()</B
>。不要对已经被
   <A
HREF="ref.info.html#ini.magic-quotes-gpc"
>magic_quotes_gpc</A
>
   转义过的字符串使用
   <B
CLASS="function"
>addslashes()</B
>,因为这样会导致双层转义。遇到这种情况时可以使用函数
   <A
HREF="function.get-magic-quotes-gpc.html"
><B
CLASS="function"
>get_magic_quotes_gpc()</B
></A
>
   进行检测。
  </P
><P
>&#13;   <TABLE
WIDTH="100%"
BORDER="0"
CELLPADDING="0"
CELLSPACING="0"
CLASS="EXAMPLE"
><TR
><TD
><DIV
CLASS="example"
><A
NAME="AEN224584"
></A
><P
><B
>例 1. <B
CLASS="function"
>addslashes()</B
> 例子</B
></P
><TABLE
BORDER="0"
BGCOLOR="#E0E0E0"
CELLPADDING="5"
><TR
><TD
><code><font color="#000000">
<font color="#0000BB">&lt;?php<br />$str </font><font color="#007700">= </font><font color="#DD0000">"Is your name O'reilly?"</font><font color="#007700">;<br /><br /></font><font color="#FF8000">// 输出:Is your name O\'reilly?<br /></font><font color="#007700">echo </font><font color="#0000BB">addslashes</font><font color="#007700">(</font><font color="#0000BB">$str</font><font color="#007700">);<br /></font><font color="#0000BB">?&gt;</font>
</font>
</code></TD
></TR
></TABLE
></DIV
></TD
></TR
></TABLE
>
  </P
><P
>&#13;   参见 <A
HREF="function.stripslashes.html"
><B
CLASS="function"
>stripslashes()</B
></A
>,<A
HREF="function.htmlspecialchars.html"
><B
CLASS="function"
>htmlspecialchars()</B
></A
>,<A
HREF="function.quotemeta.html"
><B
CLASS="function"
>quotemeta()</B
></A
>
   和 <A
HREF="function.get-magic-quotes-gpc.html"
><B
CLASS="function"
>get_magic_quotes_gpc()</B
></A
>。
  </P
></DIV
><DIV
CLASS="NAVFOOTER"
><HR
ALIGN="LEFT"
WIDTH="100%"><TABLE
SUMMARY="Footer navigation table"
WIDTH="100%"
BORDER="0"
CELLPADDING="0"
CELLSPACING="0"
><TR
><TD
WIDTH="33%"
ALIGN="left"
VALIGN="top"
><A
HREF="function.addcslashes.html"
ACCESSKEY="P"
>上一页</A
></TD
><TD
WIDTH="34%"
ALIGN="center"
VALIGN="top"
><A
HREF="index.html"
ACCESSKEY="H"
>起始页</A
></TD
><TD
WIDTH="33%"
ALIGN="right"
VALIGN="top"
><A
HREF="function.bin2hex.html"
ACCESSKEY="N"
>下一页</A
></TD
></TR
><TR
><TD
WIDTH="33%"
ALIGN="left"
VALIGN="top"
>addcslashes</TD
><TD
WIDTH="34%"
ALIGN="center"
VALIGN="top"
><A
HREF="ref.strings.html"
ACCESSKEY="U"
>上一级</A
></TD
><TD
WIDTH="33%"
ALIGN="right"
VALIGN="top"
>bin2hex</TD
></TR
></TABLE
></DIV
></BODY
></HTML
>