Zum Inhalt springen

Empfohlene Beiträge

Geschrieben

Hi,

ich habe folgenden PHP Code dazu eine MySQL Tabelle... nur der inhalt wird einfach nicht geändert ....

so sieht der link aus -->

index.php?link=100&tabelle=user&nr=5007

<?PHP

$dbserver = "localhost";

$dbname = "SMISTY";

$dbuser = "root";

$dbpasswort = "";

echo "<b>" . $tabelle . ": " . $nr . " bearbeiten</b><br>";

if($aendern)

{

if(strlen($firstname) < 1)

$fehler = 1;

if(strlen($lastname) < 1)

$fehler = 2;

if($rights < 0 || $rights > 2)

$fehler = 3;

if($fehler)

{

switch($fehler)

{

case 1: echo "<br><br>Vorname zu kurz !"; break;

case 2: echo "<br><br>Nachname zu kurz !"; break;

case 3: echo "<br><br>Rechte ungültig !"; break;

}

echo "<br><br><a href='index.php?link=100&tabelle=$tabelle&nr=$nr'>zurück</a>";

}

else

{

$db = @mysql_connect($dbserver,$dbuser,$dbpasswort) or die ("Konnte keine Verbindung zur Datenbank herstellen");

@mysql_select_db($dbname, $db) or die("Datenbank konnte nicht ausgewählt werden!");

if(strcmp($tabelle,"user") == 0)

$anfrage = "UPDATE $tabelle SET `UserFirstName` = $firstname,`UserLastName` = $lastname,`UserRights` = $rights WHERE `UserID` = $nr";

else if(strcmp($tabelle,"kamera") == 0)

$anfrage = "UPDATE $tabelle SET `UserFirstName` = $firstname,`UserLastName` = $lastname,`UserRights` = $rights WHERE `Kameranumber` = $nr";

else

$anfrage = "UPDATE $tabelle SET `UserFirstName` = $firstname,`UserLastName` = $lastname,`UserRights` = $rights WHERE `Nr` = $nr";

$ergebnis = mysql_query($anfrage, $db);

echo mysql_affected_rows($db) . "<br>" . $anfrage . "<br>Änderung erfolgreich";

mysql_close($db);

}

}

else

{

echo "<form action='index.php?tabelle=$tabelle&nr=$nr&firstname=$firstname&lastname=$lastname&rights=$rights&link=100&aendern=1' method='post'><table>";

echo "<tr><td>Vorname: </td><td><input type='text' size='20' maxlength='30' name='firstname'></td></tr>";

echo "<tr><td>Nachname: </td><td><input type='text' size='20' maxlength='30' name='lastname'></td></tr>";

echo "<tr><td>Rechte: </td><td><input type='text' size='3' maxlength='1' name='rights'></td></tr>";

echo "<tr><td colspan='2'><input type='submit' value='ändern'></td></tr>";

echo "</table></form>";

}

?>

ich habe auch die tabellenfelder mehrfach auf schreibfehler geprüft und alles stimmt !

Gruß Scratch

Geschrieben

hi,

mir fallen dazu folgende dinge ein:


$anfrage = "UPDATE $tabelle SET `UserFirstName` = $firstname,`UserLastName` = $lastname,`UserRights` = $rights WHERE `UserID` = $nr";
[/PHP]

$firstname is doch sicher ein formularfeld aus ner html-seite, oder?

wenn ja schau mal in deiner php.ini, ob dort die register globals auf on sind.

besser ist dass, wenn die auf off sind und dann könntest du beispielsweise so darauf zugreifen:

[PHP]
print $HTTP_GET_VARS["firstname"];

und die felder aus der db musst du in deinem sql statement meines wissens nach nicht in '' schreiben.

mfg korea1

Geschrieben

Hallo Scratch!

Zuerst einmal sollte man bei "externen" Variablen mit isset() prüfen, ob diese überhaupt gesetzt sind, bevor man lesend auf sie zugreift. Ausserdem sollte man auf Formularfelder bzw. URL-Parameter mit $_POST['feldname'] bzw. $_GET['feldname'] zugreifen. Letzteres bezieht sich auf aktuelle PHP-Versionen, in denen register_globals in der php.ini deaktiviert ist, so dass Formularfelder und URL-Parameter nicht automatisch in den globalen Namensraum importiert werden. Stattdessen ist auf die zuvor genannten superglobalen Felder zurückzugreifen.

if( isset( $_GET['link'] ) )
{
// Parameter "link" verarbeiten
}
else
{
// Parameter "link" nicht gesetzt
}[/PHP]

Wenn mysql_query() fehlschlägt, sollte man ausserdem immer nachschauen, was mysql_error() zur möglichen Ursache sagt...

Geschrieben

Hi,

ich bin an sowas auch schonmal verzweifelt :)

Folgender Tipp.

Statt

 $anfrage = "UPDATE $tabelle SET `UserFirstName` = $firstname,`UserLastName` = $lastname,
`UserRights` = $rights WHERE `UserID` = $nr";[/php]

Schreib mal

[php] $anfrage = "UPDATE $tabelle SET UserFirstName = '$firstname',UserLastName = '$lastname',
UserRights = '$rights' WHERE UserID = '$nr'";

Nicht die Feldnamen müssen in Klammern gesetzt werden, sondern die Variablenwerte.

Bei mir ergab das komischerweise auch kein mySQL Error ...

Geschrieben

komisch finde ich das wenn ich oben in die urlleiste des browsers schaue

index.php?tabelle=user&nr=5007&firstname=&lastname=&rights=&link=100&aendern=1

das hier steht ...

wenn ich $anfrage ausgeben steht aber

UPDATE user SET `UserFirstName` = asdf,`UserLastName` = fdsa,`UserRights` = 0 WHERE `UserID` = 5007

das da ...

echo mysql_affected_rows($db) -> gibt übrigens -1

Dein Kommentar

Du kannst jetzt schreiben und Dich später registrieren. Wenn Du ein Konto hast, melde Dich jetzt an, um unter Deinem Benutzernamen zu schreiben.

Gast
Auf dieses Thema antworten...

×   Du hast formatierten Text eingefügt.   Formatierung wiederherstellen

  Nur 75 Emojis sind erlaubt.

×   Dein Link wurde automatisch eingebettet.   Einbetten rückgängig machen und als Link darstellen

×   Dein vorheriger Inhalt wurde wiederhergestellt.   Editor leeren

×   Du kannst Bilder nicht direkt einfügen. Lade Bilder hoch oder lade sie von einer URL.

Fachinformatiker.de, 2024 by SE Internet Services

fidelogo_small.png

Schicke uns eine Nachricht!

Fachinformatiker.de ist die größte IT-Community
rund um Ausbildung, Job, Weiterbildung für IT-Fachkräfte.

Fachinformatiker.de App

Download on the App Store
Get it on Google Play

Kontakt

Hier werben?
Oder sende eine E-Mail an

Social media u. feeds

Jobboard für Fachinformatiker und IT-Fachkräfte

×
×
  • Neu erstellen...