sql >> Database teknologi >  >> RDS >> Mysql

Indlæs data fra MySQL-database til HTML-tekstbokse ved knapklik

Din forespørgsel skal være før outputtet:

Bemærk også typecastet (integer) af id'et for at sikre mod sql-injektioner.

Bemærk også sikkerhedsproblemerne med $PHP_SELF http://php.about.com/od/learnphp/qt/_SERVER_PHP .htm Jeg ændrede koden til $_SERVER['SCRIPT_NAME']

Bemærk også ikke at bruge register_globals og deaktiver det i konfigurationen, hvis du kan (brug $_SERVER['SCRIPT_NAME'] instead of $SCRIPT_NAME`) :http://www.php.net/manual/ en/security.globals.php

Hvis du lærer php fra en bog, og denne er baseret på kildekoden fra denne bog, skal du smide den væk med det samme.

<?php

//Database initialization
require_once("db_handler.php");

$conn = iniCon();
$db = selectDB($conn);

$query = "SELECT * FROM taxi_services ORDER BY SID";
$result2 = mysql_query($query, $conn);

if(isset($_POST["loadbtn"]))
{
    $id = (integer) $_POST["codes"];

    $query = "SELECT Name, Cost, Active FROM taxi_services WHERE SID = '$id' ";
    $result = mysql_query($query, $conn);
    $details = mysql_fetch_array($result);

    $savedName = $details["Name"];
    $savedCost = $details["Cost"];
    $savedActive = $details["Active"];
}

?>

<html>
<head>
</head>
<body>

<div id="upserv">
<b id="caption2">Update location</b>
<br/><br/>
    <form name="upServForm" action="<?php echo $_SERVER['SCRIPT_NAME']; ?>" method="post" >
        <?php
        $dropdown = "<select name='codes'>";
        while($row = mysql_fetch_assoc($result2)) 
        {
            $dropdown .= "\r\n<option value='{$row['SID']}'>{$row['SID']}</option>";
        }
        $dropdown .= "\r\n</select>";
    ?>
     Service ID  <?php echo $dropdown; ?> <input type="submit" value="Load" name="loadbtn">
        <table width="300" border="0">
          <tr>
            <td>Name</td>
            <td><input type="text" name="upName" style="text-align:right" value="<? echo $savedName; ?>" /></td>
          </tr>
          <tr>
            <td>Cost</td>
            <td><input type="text" name="upCost" style="text-align:right" value="<? echo $savedCost; ?>" /></td>
          </tr>
          <tr>
            <td>Active</td>
            <td><input type="checkbox" name="upActive" value="<? echo $savedActive; ?>" /></td>
          </tr>
        </table>
</div>
<br/>
<div id="buttons">
    <input type="reset" value="Clear" /> <input type="submit" value="Save" name="updatebtn" />
</div>
    </form>

</body>
</html>



  1. MySQL til at udfylde manglende datoer, når du bruger GROUP BY DATE(table.timestamp) uden at deltage i den midlertidige tabel

  2. mysql-struktur til indlæg og kommentarer

  3. det leverede argument er ikke en gyldig MySQL-resultatressource

  4. VÆLG række efter DATEPART()