5 – Sende innlegg med AJAX



5 – Sende innlegg med AJAX

av Ole Petter den 3. oktober 2019

Sist oppdatert: 25 oktober, 2019 kl 15:51

Asynkron javascript og XML, forkortet til Ajax er en webutviklingsteknikk som kort fortalt dreier seg om å laste inn små elementer til en side uten å laste inn hele siden på nytt hver gang det skjer en forandring.

For å sende informasjon til en database i form av et skjema, og hente informasjonen på en nettside, må man bruke AJAX eller liknende teknikker. I PHP gjøres dette i form av en XMLhttpRequest.

I dette eksempelet brukes et vanlig html-skjema som sendes til en annen fil (insert.php) for å behandle forespørselen. Hvis forespørselen blir godkjent, og databasen oppdatert, kan denne nye informasjonen hentes på index-siden.

Skjemaet som sender informasjon til insert.php

For å sende informasjonen til insert.php brukes jquery. Derfor må dette biblioteket inkluderes. CDN kan finnes på linken: https://code.jquery.com/

Tips: Ikke bruk slim-versjonen, ajax virker kun på .min-versjonen, eller uncompressed.

(Jeg brukte versjon 3.11 i dette eksempelet)

jQuery-koden som behandler skjemaet.

Skjemaet (form) har en id-tag med navn my-form, som hentes ved hjelp av en funksjon, og «e.preventDefault()» forhindrer at siden lastes inn på nytt når send-knappen trykkes.

Videre sendes dataen til filen «insert.php», og dataen som sendes blir prosessert i en jQuery-funksjon kalt «serialize()». Dette gjør at dataen sendes i URL til «insert.php» akkurat som en GET-request, men metoden som brukes er POST, så dataen vises ikke i URL.

Hvis skjemaet sendes lagres beskjeden fra «insert.php» i «#message», som er plassert like over skjemaet. Når skjemaet er sendt blir innholdet fjernet via «reset()», som er en funksjon i javascript som fjerner innholdet i input-elementer med samme id som i reset-funksjonen. Dette må da korrespondere med id-en til skjemaet, som i dette tilfellet er «#my-form».

Tilkobling til databasen
Databasen – kalt ajax_movies

Hvis tilkoblingen til databasen – i dette tilfellet kalt «ajax-movies» – er vellykket, kan data sendes til databasen via AJAX. Da må dataene som er sendt fra skjemaet behandles i script-taggen og videresendes til «insert.php».

Verdiene som sendes fra skjemaet

Før dataene sendes til databasen må de valideres. Som nevnt i en tidligere artikkel brukes «mysqli_real_escape_string» til å fjerne risiko for SQL-injection, altså å fjerne script som kan manipulere databasen, og gjøre dem om til harmløs tekst.

Deretter sjekkes skjemaene, hvis de ikke er fylt ut vil man via #message få beskjed om å fylle inn dataene på nytt.

Sjekker om påkrevde felter er fylt ut

Hvis alle feltene er fylt ut sendes skjemaet til databasen og legger til en ny film i tabellen «movies».

Kildekode

Skjemaet i index.php
Scriptet som behandler skjemaet og sender det til «insert.php»
insert.php
1 Kommentarer
Toby

It's a shame you don't have a donate button! I'd without a doubt donate to this fantastic blog! I suppose for now i'll settle for bookmarking and adding your RSS feed to my Google account. I look forward to brand new updates and will share this site with my Facebook group. Talk soon! Also visit my website: pixel gun 3d hack

Legg igjen en kommentar