<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <HTML ><HEAD ><TITLE >为什么不用魔术引号</TITLE ><META NAME="GENERATOR" CONTENT="Modular DocBook HTML Stylesheet Version 1.79"><LINK REL="HOME" TITLE="PHP 手册" HREF="index.html"><LINK REL="UP" TITLE="魔术引号" HREF="security.magicquotes.html"><LINK REL="PREVIOUS" TITLE="为什么要用魔术引号" HREF="security.magicquotes.why.html"><LINK REL="NEXT" TITLE="关闭魔术引号" HREF="security.magicquotes.disabling.html"><META HTTP-EQUIV="Content-type" CONTENT="text/html; charset=UTF-8"></HEAD ><BODY CLASS="sect1" 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="security.magicquotes.why.html" ACCESSKEY="P" >上一页</A ></TD ><TD WIDTH="80%" ALIGN="center" VALIGN="bottom" >章 31. 魔术引号</TD ><TD WIDTH="10%" ALIGN="right" VALIGN="bottom" ><A HREF="security.magicquotes.disabling.html" ACCESSKEY="N" >下一页</A ></TD ></TR ></TABLE ><HR ALIGN="LEFT" WIDTH="100%"></DIV ><DIV CLASS="sect1" ><H1 CLASS="sect1" ><A NAME="security.magicquotes.whynot" >为什么不用魔术引号</A ></H1 ><P ></P ><UL ><LI ><P > 可移植性 </P ><P > 编程时认为其打开或并闭都会影响到移植性。可以用 <A HREF="function.get-magic-quotes-gpc.html" ><B CLASS="function" >get_magic_quotes_gpc()</B ></A > 来检查是否打开,并据此编程。 </P ></LI ><LI ><P > 性能 </P ><P > 由于并不是每一段被转义的数据都要插入数据库的,如果所有进入 PHP 的数据都被转义的话,那么会对程序的执行效率产生一定的影响。在运行时调用转义函数(如 <A HREF="function.addslashes.html" ><B CLASS="function" >addslashes()</B ></A >)更有效率。 </P ><P > 尽管 <TT CLASS="filename" >php.ini-dist</TT > 默认打开了这个选项,但是 <TT CLASS="filename" >php.ini-recommended</TT > 默认却关闭了它,主要是出于性能的考虑。 </P ></LI ><LI ><P > 不便 </P ><P > 由于不是所有数据都需要转义,在不需要转义的地方看到转义的数据就很烦。比如说通过表单发送邮件,结果看到一大堆的 \'。针对这个问题,可以使用 <A HREF="function.stripslashes.html" ><B CLASS="function" >stripslashes()</B ></A > 函数处理。 </P ></LI ></UL ></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="security.magicquotes.why.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="security.magicquotes.disabling.html" ACCESSKEY="N" >下一页</A ></TD ></TR ><TR ><TD WIDTH="33%" ALIGN="left" VALIGN="top" >为什么要用魔术引号</TD ><TD WIDTH="34%" ALIGN="center" VALIGN="top" ><A HREF="security.magicquotes.html" ACCESSKEY="U" >上一级</A ></TD ><TD WIDTH="33%" ALIGN="right" VALIGN="top" >关闭魔术引号</TD ></TR ></TABLE ></DIV ></BODY ></HTML >