Pagina 1 di 2 1 2 ultimoultimo
Visualizzazione dei risultati da 1 a 10 su 19
  1. #1

    Problema guida pratica PHP mySQL

    Salve a tutti. Sto' seguendo la guida pratica di php MySQLdi html.it e tutto cio' che c'era scritto funzionava fino al momento di inserire gli articoli.
    Ecco le pagine con i loro codici

    config.inc.php
    Codice PHP:
    <?
    // parametri del database
    $db_host "localhost";
    $db_user "root";
    $db_password "miapassword";
    $db_name "prove";
    //password per inserimento articoli
    $password "abc";
    ?>

    intall.php
    Codice PHP:
    <?
    include("config.inc.php");
    $db mysql_connect($db_host$db_user$db_password);
    if (
    $db == FALSE)
    die (
    "Errore nella connessione. Verificare i parametri nel file config.inc.php");
    mysql_select_db($db_name$db)
    or die (
    "Errore nella selezione del database. Verificare i parametri nel file config.inc.php");
    $query "CREATE TABLE news (id INT (5) UNSIGNED not null AUTO_INCREMENT, titolo VARCHAR (255) not null , testo TEXT not null , data INT (11) , autore VARCHAR (50) , mail VARCHAR (50) , PRIMARY KEY (id))";
    if (
    mysql_query($query$db))
    echo 
    "L'installazione è stata eseguita correttamente";
    else
    echo 
    "Errore durante l'installazione";
    mysql_close($db);
    ?>

    top_foot.inc.php
    Codice PHP:
    <? function top() { ?>
    <HTML>
    <HEAD>
    <meta name=generator content="Script di freephp.it">
    </HEAD>
    <BODY bgcolor=ffffff text=000000>
    <font face=verdana,tahoma,arial size=-1>
    <h1>FREEPHP.IT</h1>

    <? }

    function 
    foot() { ?>
    </body></HTML>
    <? ?>

    insert.php
    Codice PHP:
    <?
    include ("config.inc.php");
    include (
    "top_foot.inc.php");

    //intestazione
    top();
    ?>

    <form method=post action=save.php>
    Titolo:

    <input type=text size=40 name=titolo>



    Data:

    <select name=giorno>
    <?
    for ($i=1$i<=31$i++)
    echo 
    "<option value=$i>$i";
    ?>
    </select>
    <select name=mese>
    <option value=1>Gennaio
    <option value=2>Febbraio
    <option value=3>Marzo
    <option value=4>Aprile
    <option value=5>Maggio
    <option value=6>Giugno
    <option value=7>Luglio
    <option value=8>Agosto
    <option value=9>Settembre
    <option value=10>Ottobre
    <option value=11>Novembre
    <option value=12>Dicembre
    </select>
    <select name=anno>
    <option value=2001>2001
    <option value=2002>2002
    <option value=2003>2003
    <option value=2004>2004
    <option value=2005>2005
    </select>



    Autore:

    <input type=text size=40 name=autore>



    E-mail:

    <input type=text size=40 name=mail>



    Testo:

    <textarea cols=60 rows=40 name=testo></textarea>



    Password:

    <input type=password size=40 name=pass>



     <input type=submit value=Invia> </form>
    <?
    // chiusura pagina
    foot();
    ?>

    save.php
    Codice PHP:
    <? include("top_foot.inc.php");
    include(
    "config.inc.php");
    top();
    if (
    $pass != $password):
    echo 
    "Password errata";
    elseif (
    trim($titolo) == "" OR trim($testo) == ""):
    echo 
    "I campi Titolo e Testo devono essere riempiti!";
    else:
    $titolo addslashes(stripslashes($titolo));
    $autore addslashes(stripslashes($autore));
    $mail addslashes(stripslashes($mail));
    $testo addslashes(stripslashes($testo));
    $titolo str_replace("<""&lt;"$titolo);
    $titolo str_replace(">""&gt;"$titolo);
    $autore str_replace("<""&lt;"$autore);
    $autore str_replace(">""&gt;"$autore);
    $testo str_replace("<""&lt;"$testo);
    $testo str_replace(">""&gt;"$testo);
    $testo nl2br($testo);
    $data mktime("0""0""0"$mese$giorno$anno);
    $db mysql_connect($db_host$db_user$db_password);
    if (
    $db == FALSE)
    die (
    "Errore nella connessione. Verificare i parametri nel file config.inc.php");
    mysql_select_db($db_name$db)
    or die (
    "Errore nella selezione del database. Verificare i parametri nel file config.inc.php");
    $query "INSERT INTO news (titolo, testo, data, autore, mail) VALUES ('$titolo', '$testo', '$data', '$autore', '$mail')";
    if (
    mysql_query($query$db))
    echo 
    "L'articolo è stato inserito correttamente";
    else
    echo 
    "Erorre durante l'inserimento";
    mysql_close($db); endif;
    foot();
    ?>
    _____________________________


    La creazione della tabella avviene senza problemi ma all'inserimento dell'articolo la pagina save.php mi dice che la password inserita sbagliata anche se io sono certo di scriverla giusta.
    Da cosa proviene questo errore?
    Ho provato a controllare la parte di codice relativa al controllo della password ma mi sembra logicamente giusto.
    Consigli?

    Grazie

  2. #2
    prova a stampare da save le due password
    Tremal-Naik
    ******************************
    passa a LINUX
    **********
    la religione e' il freno che impedisce al povero di ammazzare il ricco

  3. #3
    Utente di HTML.it
    Registrato dal
    Aug 2002
    Messaggi
    8,013
    Putroppo la guida è un po' datata e qualche cosa non va più come una volta (motivi di sicurezza): per recuperare pass dal form non devi più fare $pass ma $_POST['pass']

    Ossia, i form che passano i dati in post, non li passeranno più a variabili col nome identico al nome del form, ma all'array $_POST all'indice pari al nome dell'elemento del form

    prova quindi a fare
    if ($_POST['pass'] != $password)

    Attenzione che è buona norma mettere le virgolette nel codice html
    <input type="password" name="pass" />
    <´¯)(¯`¤._)(¯`»ANDREA«´¯)(_.¤´¯)(¯`>
    "The answer to your question is: welcome to tomorrow"

  4. #4
    Non stampa nessuno dei valori che quel form avrebbe dovuto inviargli via post (password, autore, mail, testo etc)... ho provato a controllare il codice di insert.php ma mi sembra corretto.
    Ho notato che nel codice html mancavano le "" in ogni proprietà di ogni tag e le ho aggiunte ma non cambia niente... stampa soltanto l valore della password presente in confing.inc.php
    Possibile che in locale non funzioni il metodo post?

  5. #5
    Ecco perfetto!
    Vedo che abbiamo risposto assieme adesso provo a modificare il codice php

  6. #6
    Utente di HTML.it
    Registrato dal
    Aug 2002
    Messaggi
    8,013
    editato...
    <´¯)(¯`¤._)(¯`»ANDREA«´¯)(_.¤´¯)(¯`>
    "The answer to your question is: welcome to tomorrow"

  7. #7
    Ecco il nuovo codice:

    insert.php
    Codice PHP:
    <?
    include ("config.inc.php");
    include (
    "top_foot.inc.php");

    //intestazione
    top();
    ?>

    <form method="post" action="save.php">
    Titolo:

    <input type="text" size="40" name="titolo">



    Data:

    <select name="giorno">
    <?
    for ($i=1$i<=31$i++)
    echo 
    "<option value=$i>$i";
    ?>
    </select>
    <select name="mese">
    <option value="1">Gennaio
    <option value="2>Febbraio
    <option value="3">Marzo
    <option value="4">Aprile
    <option value="5">Maggio
    <option value="6">Giugno
    <option value="7">Luglio
    <option value="8">Agosto
    <option value="9">Settembre
    <option value="10">Ottobre
    <option value="11">Novembre
    <option value="12">Dicembre
    </select>
    <select name="anno">
    <option value="2001">2001
    <option value="2002">2002
    <option value="2003">2003
    <option value="2004">2004
    <option value="2005">2005
    </select>



    Autore:

    <input type="text" size="40" name="autore">



    E-mail:

    <input type="text" size="40" name="mail">



    Testo:

    <textarea cols="60" rows="40" name="testo"></textarea>



    Password:

    <input type="password" size="40" name="pass">



     <input type="submit" value="Invia"> </form>
    <?
    // chiusura pagina
    foot();
    ?>

    save.php
    Codice PHP:
    <? include("top_foot.inc.php");
    include(
    "config.inc.php");
    top();
    $pass $_POST['pass'];
    $titolo $_POST['titolo'];
    $autore $_POST['autore'];
    $testo $_POST['testo'];
    $data $_POST['data'];
    $mese $_POST['mese'];
    $giorno $_POST['giorno'];
    $anno $_POST['anno'];
    $mail $_POST['mail'];

    if (
    $pass != $password){
        echo 
    "Password errata";
    }
    elseif (
    trim($titolo) == "" OR trim($testo) == ""){
        echo 
    "I campi Titolo e Testo devono essere riempiti!";
    }
    else{
        
    $titolo addslashes(stripslashes($titolo));
        
    $autore addslashes(stripslashes($autore));
        
    $mail addslashes(stripslashes($mail));
        
    $testo addslashes(stripslashes($testo));
        
    $titolo str_replace("<""&lt;"$titolo);
        
    $titolo str_replace(">""&gt;"$titolo);
        
    $autore str_replace("<""&lt;"$autore);
        
    $autore str_replace(">""&gt;"$autore);
        
    $testo str_replace("<""&lt;"$testo);
        
    $testo str_replace(">""&gt;"$testo);
        
    $testo nl2br($testo);
        
    $data mktime("0""0""0"$mese$giorno$anno);
        
    $db mysql_connect($db_host$db_user$db_password);
    }
    if (
    $db == FALSE){
        die (
    "Errore nella connessione. Verificare i parametri nel file config.inc.php");
        
    mysql_select_db($db_name$db)
        or die (
    "Errore nella selezione del database. Verificare i parametri nel file config.inc.php");
        
    $query "INSERT INTO news (titolo, testo, data, autore, mail) VALUES ('$titolo', '$testo', '$data', '$autore', '$mail')";
    }
    if (
    mysql_query($query$db)){
        echo 
    "L'articolo ? stato inserito correttamente";
    }
    else{
        echo 
    "Erorre durante l'inserimento";
        
    mysql_close($db);
    }
    foot();
    ?>

    Adesso non mi da' (giustamente) ne l'errore nella password ne nel testo e titolo vuoti.
    Purtroppo c'è "Erorre durante l'inserimento".
    Ho quindi provato a guardare nel database ed in effetti non c'è l'articolo... da cosa puo' derivare il problema?

  8. #8
    echo $query
    vedi cosa stampa
    Tremal-Naik
    ******************************
    passa a LINUX
    **********
    la religione e' il freno che impedisce al povero di ammazzare il ricco

  9. #9
    Sfortunatamente non stampa niente quindi presumo l'errore si trovi in questa parte di codice:

    Codice PHP:
    ....
    $query "INSERT INTO news (titolo, testo, data, autore, mail) VALUES ('$titolo', '$testo', '$data', '$autore', '$mail')";
    }
    if (
    mysql_query($query$db)){
    .... 

  10. #10
    mysql_select_db($db_name, $db)
    mysql_select_db($db_name, $db) ;
    sembra manchi un ;
    Tremal-Naik
    ******************************
    passa a LINUX
    **********
    la religione e' il freno che impedisce al povero di ammazzare il ricco

Permessi di invio

  • Non puoi inserire discussioni
  • Non puoi inserire repliche
  • Non puoi inserire allegati
  • Non puoi modificare i tuoi messaggi
  •  
Powered by vBulletin® Version 4.2.1
Copyright © 2025 vBulletin Solutions, Inc. All rights reserved.