Oprettet tir. d. 09. marts 2010 kl. 10:27:52

Maylind
Maylind (3.685 point. Point ude: 265)

Hvorfor smider den ikke ind i databasen?

Har dette søge script som virker fint, men hvis man søger på et navn og det dukker op skal man kunne tilføje personen som ven. men der har jeg et problem med at det ikke bliver sent ind i min tabel i databasen "venner" kan i se hvad jeg gør galt?


function venner($conn){
//Her kan man søge på nye venner
    echo '
        <form method="post" action="?page=venner" class="login">
            S&oslash;g ven:
                <input type="text" name="search">
                    <input type="submit" name="submit" value="S&oslash;g">
        </form>';
       
            if (isset($_POST['submit'])) {
                $query = "select * from opret WHERE navn LIKE '%".$_POST['search']."%' OR email LIKE '%".$_POST['search']."%'";
                    $result = mysqli_query($conn, $query);
       
                        if (isset($_POST['search']) && !empty($_POST['search'])) {
                            echo "<br /><br />Her kan du se de venner du s&oslash;gte p&aring;:<br><br><hr />";
                                echo "<table width=90% align=center border=1><tr>
                                <td align=center bgcolor=#00FFFF>Navn</td>
                                <td align=center bgcolor=#00FFFF>Email</td>
                                <td align=center bgcolor=#00FFFF>Tilf&oslash;j som ven</td>
                                </tr>";
                                //Her kan man tilføje til sin venneliste
                                    while ($r = mysqli_fetch_array($result)) {
                                        $navn = $r["navn"];
                                        $mail = $r["email"];
                                            echo "<tr>
                                            <td>$navn</td>
                                            <td>$mail</td>
                                            <td>
                                            <form method='post' action='?page=tilfojven'>
                                                <input type='submit' name='ok' value='Tilf&oslash;j' />
                                            </form><br /></td>
                                            </tr>";
                                                if(isset($_POST['ok'])){
                                                    $strnavn = $_POST['navn'];
                                                    $strmail = $_POST['email'];
                                                   
                                                    $x = mysqli_query($conn,"INSERT INTO venner (navn, email) VALUES ('".$strnavn."','".$strmail."')");
                                                };
                                    };
                                                    echo "</table>";
                                                }else{
                                           
                        };
            };     
};

Skrevet tir. d. 09. marts 2010 kl. 10:35:54| #1

Fordi din logik fejler.
if( isset($_POST["submit"]) )
{
  if( isset($_POST["ok"]) )
  {

  }

}


Når du har trykket på knappen navngivet 'ok' vil $_POST["submit"] ikke længere evalueres som 'true' i din første sætning og derfor kommer du ikke ind til den del der sætter vennen i databasen.

Tag også lige at google på SQL injections, når du får tid.

Skrevet tir. d. 09. marts 2010 kl. 10:41:05| #2

Maylind
Maylind (3.685 point)
jamen det jo ikke samme knap:) sorry er også ret ny inden for php

Skrevet tir. d. 09. marts 2010 kl. 10:57:39| #3

Du har ret i det ikke er den samme knap - men det at det ikke virker er logisk set korrekt.

En simpel sammenligning af det du - i den logiske sammenhæng forsøger at gøre - kan beskrives med at det svarer til at du først låser din bil op, og derefter skal tage stilling til om du vil starte din bil. Når du s har gjort det bliver du nød til at låse din bil op SAMTIDIG med at du vil starte bilen med samme nøgle. Det er umuligt - set i et logisk perspektiv.

Det lader nu også til at du har dynamiske sider? ?page=venner - hvad gør den? Inkluderer en fil ud fra ?page? I så fald, ville jeg da antage at ?page=tilfoejven også må pege et andet sted hen?

Skrevet man. d. 15. marts 2010 kl. 11:30:09| #4


Skriv et indlæg




Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] [img]link til billede[/img]
Web- og emailadresser omdannes automatisk til links

Log ind

   

   

Seneste spørgsmål

Inspion Economy søger en dygtig programmør, som kan...

Oprettet den 10. februar 2012 kl. 16.23
Kathja giver 15 point for svar | Giv et svar »

Socialt Netværk system søges (WP eller andet)

Oprettet den 9. februar 2012 kl. 22.23
zimonb giver 30 point for svar | Giv et svar »

Joomla - JomSocial

Oprettet den 9. februar 2012 kl. 18.04
zimonb giver 30 point for svar | Giv et svar »

Seneste guides

Installer win 7
Den gode bruger


   




Tips & Tricks fra PC World

Teaser billede

Her er fem sjove danske websider du skal kende

Trænger dine lattermuskler til en omgang fitness på dansk? Vi viser vej til fem websider fyldt med humor og vanvittig satire.


Anmeldelser fra PC World

Teaser billede

Test: Denne super-tablet er iPads hårdeste konkurrent

Eee Pad Transformer Prime er frygtindgydende med sin quadcore processor og evne til at trylle sig om til bærbar. Apple bør kigge i bagspejlet, for Asus' tablet-pc kommer buldrende - og gør det...


Seneste blogindlæg

Teaser billede

Tvangslukke spørgsmål: Hvad er den bedste løsning?

Hej Vi har mange åbne spørgsmål på Eksperten. Vi ville gerne tvangslukke dem - så et spørgsmål efter f.eks. 6 måneder lukkes. Men der er et par uklarheder som ville være gode at få lidt input til:...


Nyheder fra PC World

Teaser billede

Nu kan du snart hente Windows 8

Den nye offentlige betaversion af Windows 8 er klar i denne måned.


Nyheder fra Computerworld

Teaser billede

Måske snart slut med Androids helt store problem

Android-platformen har længe været plaget af et særligt problem. Men måske er problemet nu ved at være elimineret.


Kurser
Samarbejdspartnere

Udgiver · © 2012 IDG Danmark A/S · Hørkær 18 · 2730 Herlev · Tlf.: 77 300 300 · Fax: 77 300 301 · Brug af personoplysninger