Bei der Entwicklung von ajax Vue.js Anwendungen habe ich nach Jahren endlich herausgefunden, wie man ajax in PHP verwenden kann und wie man Daten per POST Methode erhält.
$_POST
ist nur für Formulare verfügbarIn PHP ist die superglobale Variable $_POST
allgemein verfügbar, um die übermittelten Daten aus einem Formular zu speichern.
Es ist relativ einfach zu bedienen.
Auf der HTML-Seite müssen Sie ein Formular erstellen:
<form action="process.php" method="post">Jméno: <input type="text" name="username"><input type="submit" value="Odeslat"></form>
In der Datei process.php
kann dann auf die Werte als Array-Elemente zugegriffen werden:
echo htmlspecialchars($_POST['Nutzername'] ?? '');
Warnung:
Mit diesem einfachen Ansatz könnte jeder denken, dass POSTed-Daten automatisch als Array-Indizes in der Variable
$_POST
definiert sind. Aber das ist nicht wahr!
Der Grund, warum Daten, die von einem Formular mit der POST-Methode gesendet werden, in die Variable $_POST
geschrieben werden, liegt darin, dass der Browser automatisch den HTTP-Header 'Content-Type': 'application/x-www-form-urlencoded'
sendet, wenn das HTML-Formular abgeschickt wird.
Ohne eine richtig gesetzte Kopfzeile kann auf die Werte nicht zugegriffen werden, und wir müssen zu einer Tricklösung greifen.
Wenn wir versuchen, Daten über Ajax zu senden, müssen wir den Ansatz auf der PHP-Seite ein wenig ändern. Sie können die Diskussion auf Facebook lesen, um Einzelheiten zu erfahren.
In Javascript können Sie zum Beispiel die axios-Bibliothek verwenden, um Daten per Ajax zu senden. Um es einfach zu nutzen, verlinken Sie einfach Javascript vom CDN-Server und verwenden es sofort:
<script src="https://unpkg.com/axios/dist/axios.min.js"></script><script>axios.post('/api/form-process', {username: 'Jméno uživatele'}).then(response => {// Zpracování odpovědi z APIalert(response.data.message); // Vyhodí hlášku se zprávou});</script>
In diesem einfachen Fall wird die URL '/api/form-process'
über Ajax aufgerufen und die POST-Methode übergibt das Objekt { username: 'User name' }
. Die Bibliothek selbst kümmert sich bereits automatisch um die Logistik der Datenübergabe, so dass sie als Json serialisiert gesendet werden. Im Sprachgebrauch der Frontend-Entwickler wird dies json payload genannt.
Auf der PHP-Seite würde ich erwarten, dass es als Formular verwendet wird (schließlich war es eine POST-Methode):
echo htmlspecialchars($_POST['Nutzername'] ?? '');
In diesem Fall ist das Feld "$_POST" jedoch leer und es werden keine Daten übergeben. Die Variable $_POST
wird nur für Daten verwendet, die von Formularen abgerufen werden (Sie erkennen das an dem HTTP-Header, den wir nicht weggeworfen haben).
In diesem Fall müssen wir also die Daten direkt aus der HTTP-Anfrage abrufen, wofür die Tricklösung verwendet wird. Es ist dann einfach zu benutzen:
$data = json_decode(file_get_contents('php://eingabe'), true);echo htmlspecialchars($data['Nutzername'] ?? '');header('Inhalt-Typ: application/json');echo json_encode(['Nachricht' => 'Der Server-Schleicher',]);die;
Als Beispiel gebe ich auch eine einfache Javascript-Antwort. Wichtig ist, dass der HTTP-Header 'Content-Type: application/json'
richtig gesetzt wird und das Skript beendet wird, nachdem alle Daten gesendet wurden.
$_POST
Wenn Sie die übermittelten Daten dennoch direkt als Formular behandeln wollen, gibt es eine Möglichkeit, sie zu übertragen. In diesem Fall müssen Sie die Erstellung der Ajax-Abfrage selbst ändern und die HTTP-Header korrekt übergeben:
axios.post('/api/form-process',{username: 'Jméno uživatele'},{headers: {'Content-Type': 'application/x-www-form-urlencoded'}}).then(response => {// Nějaké zpracování});
In diesem Fall wird die Verarbeitung auf der PHP-Seite jedoch nicht angenehm sein, da wir die Daten noch korrigieren und in ein Array umwandeln müssen.
Ich habe es geschafft, diesen Horror zu erfinden:
if (\count($_POST) === 1&& preg_match('/^\{.*\}$/', $post = array_keys($_POST)[0])&& ($json = json_decode($post)) instanceof \stdClass) {foreach ($json as $key => $value) {$_POST[$key] = $value;unset($_POST[$post]);}}echo htmlspecialchars($_POST['Nutzername'] ?? '');
Es ist jedoch viel besser, sich an den ersten Ansatz zu halten und die Methode 'php://input'
zu verwenden, um die Daten zu erhalten.
Jan Barášek Více o autorovi
Autor článku pracuje jako seniorní vývojář a software architekt v Praze. Navrhuje a spravuje velké webové aplikace, které znáte a používáte. Od roku 2009 nabral bohaté zkušenosti, které tímto webem předává dál.
Rád vám pomůžu:
Články píše Jan Barášek © 2009-2024 | Kontakt | Mapa webu
Status | Aktualizováno: ... | de