I don't see why addslashes wouldn't work, but why not roll your own? $dbStr = preg_replace("/'/", "/\\'/");
I believe that, in MySQL, you can also double-up single quotes to escape them: $dbStr = preg_replace("/'/", "/''/"); HTH Matt On Wed, 27 Feb 2002, Tim Thorburn wrote: > Hi, > > I've sent a few emails thus far regarding adding apostrophe's through a PHP > script form into a MySQL database. The responses I received indicated to > me that I needed to get my hosting company to activate magic_quotes_gpc. > > After several days of talking with what seems to be the sole tech support > person left at my hosting company - I was told that the magic_quotes_gpc > variable is not supported by them. > > Sooo ... this leaves me in a rather awkward situation. I need to have a > basic content management system up and running in the extremely near future > that will be utilized by a great number of individuals. If when an > apostrophe is entered - all the information entered through the form is > rejected by the database - the entire endeavour suddenly becomes rather > useless. > > I know that if I enter a \ before any apostrophe's in the form, it all > works well ... but I highly doubt that the large number of volunteer's > we're going to be working with here will take the time to add them, or even > remember 5 minutes after I tell them. > > Does anyone have any possible solutions for this problem? I'll include the > portion of code that seems to be causing the problems now ... > > I'm already using the addslashes() command and it is not working ... I'm > desperate at this point ... > > Again, the following works flawlessly on my local test machine running > Apache 1.3.23 and PHP 4.1.1 with MySQL 3.23.39 but not at all on my web > host running Apache 1.3.12 and PHP 3.0.16 with MySQL 3.22.32 > > Thanks in advance, > -Tim > > > <?php > $db = mysql_connect("localhost", "xxxx", "xxxx"); > mysql_select_db("edoinfo",$db); > > if ($submit) { > // here if no ID then adding else we're editing > if ($id) { > $sql = "UPDATE ai_data SET > >section='$section',subsection='$subsection',heading='$heading',title='$title',info='$info',entry=NOW() > WHERE id=$id"; > } else { > $sql = "INSERT INTO ai_data > (section,subsection,heading,title,info,entry) VALUES > ('$section','$subsection','$heading','$title','$info',NOW())"; > } > // run SQL against the DB > $result = mysql_query($sql); > echo "Record updated/edited!<p>"; > echo "<a href='add_info.php' class='comcal'>ADD A RECORD</a>"; > > } elseif ($delete) { > // delete a record > $sql = "DELETE FROM ai_data WHERE id=$id"; > > $result = mysql_query($sql); > > echo "$sql Record deleted!<p>"; > echo "<a href='add_info.php' class='comcal'>ADD A RECORD</a>"; > > } else { > // this part happens if we don't press submit > if (!$id) { > // print the list if there is not editing > $result = mysql_query("SELECT * FROM ai_data",$db); > while ($myrow = mysql_fetch_array($result)) { > printf("<a href=\"%s?id=%s\" class='comcal'>%s</a> \n", $PHP_SELF, > $myrow["id"], $myrow["title"]); > > printf("<a href=\"%s?id=%s&delete=yes\" class='comcal'>(DELETE)</a><br>", > $PHP_SELF, $myrow["id"]); > } > } > > ?> > <p> <a href="<?php echo $PHP_SELF?>" class="comcal">ADD A RECORD</a> > <p> <form method="post" action="<?php echo $PHP_SELF?>"> > <?php > if ($id) { > // editing so select a record > $sql = "SELECT * FROM ai_data WHERE id=$id"; > $result = mysql_query($sql); > $myrow = mysql_fetch_array($result); > > $id = $myrow["id"]; > $section = $myrow["section"]; > $subsection = $myrow["subsection"]; > $heading = $myrow["heading"]; > $title = addslashes($myrow["title"]); > $info = addslashes($myrow["info"]); > $entry = $myrow["entry"]; > > // print the id for editing > ?> > <input type=hidden name="id" value="<?php echo $id ?>"> > <?php > } > ?> > </td> > <td align="left" valign="top">Section<font size="1"></font>:</td> > <td align="left" valign="top"> > <input type="text" name="section" value="<?php echo $section ?>" > size="35" maxlength="100" <?php include('../../../scripts/forms.css'); ?>> > </td> > </tr> > <tr> > <td align="left" valign="top">Sub-Section: </td> > <td align="left" valign="top"> > <input type="text" name="subsection" value="<?php echo $subsection > ?>" size="35" maxlength="100" <?php include('../../../scripts/forms.css'); ?>> > </td> > </tr> > <tr> > <td align="left" valign="top">Heading Graphic: </td> > <td align="left" valign="top"> > <input type="text" name="heading" value="<?php echo $heading ?>" > size="35" maxlength="255" <?php include('../../../scripts/forms.css'); ?>> > </td> > </tr> > <tr> > <td align="left" valign="top">Section Title: </td> > <td align="left" valign="top"> > <input type="text" name="title" value="<?php echo $title ?>" > size="35" maxlength="255" <?php include('../../../scripts/forms.css'); ?>> > </td> > </tr> > <tr> > <td align="left" valign="top" colspan="2"> </td> > </tr> > <tr> > <td align="left" valign="top">Document Information: </td> > <td align="left" valign="top"> > <textarea cols="35" name="info" rows="5" <?php > include('../../../scripts/forms.css'); ?>><?php echo $info ?></textarea> > </td> > </tr> > <tr> > <td align="left" valign="top"> </td> > <td align="left" valign="top"> </td> > </tr> > <tr> > <td align="left" valign="top">Event Entry: </td> > <td align="left" valign="top"> > <?php echo $entry ?> > </td> > </tr> > <tr> > <td align="left" valign="top"> </td> > <td align="left" valign="top"> </td> > </tr> > <tr> > <td align="left" valign="top"> > <input type="Submit" name="submit" value="Enter information" > border=0 alt="Enter Information" style="background-color: 000000; > font-size: 14; color: cccccc;"> > </td> > <td align="left" valign="top"> </td> > </tr> > <tr> > <td align="left" valign="top"> </td> > <td align="left" valign="top"> </td> > </tr> > </table> > </form> > > <?php > } > ?> > > > > -- > PHP General Mailing List (http://www.php.net/) > To unsubscribe, visit: http://www.php.net/unsub.php > -- PHP General Mailing List (http://www.php.net/) To unsubscribe, visit: http://www.php.net/unsub.php