• User

    Ho testatoil file, ma esce scritto :"Tutti i campi devono essere valorizzati"


  • User

    Sto realizzando anche la pagina login.php seguendo le direttive di thedarkita.
    Il valore Livello che ho inserito nella pagina accedi.php mi serve per abilitare gli utenti: in fase di registrazione è settato a 0 e non si può accedere all'area privata, poi sono io che lo modifico a 1 direttamente su mysql, abilitando l'utente nell'area privata.
    Posto il codice della pagina login e quello della pagina accedi che dovrebbe ricevere i dati del form, perchè mi esce pagina bianca
    Dov'è che sbaglio?

    [HTML]<form action="accedi.php" method="post" name="login" id="login">
    <table width="36%" border="0" align="center" cellpadding="0" cellspacing="0">
    <tr>
    <td width="26%"><font color="#000099" face="Arial, Helvetica, sans-serif"><strong>Email
    :</strong></font></td>
    <td width="74%"><input name="email" type="text" id="email"></td>
    </tr>
    <tr>
    <td> </td>
    <td> </td>
    </tr>
    <tr>
    <td><font color="#000099" face="Arial, Helvetica, sans-serif"><strong>Password
    :</strong></font></td>
    <td><input name="password" type="password" id="password"></td>
    </tr>
    <tr>
    <td> </td>
    <td> </td>
    </tr>
    <tr>
    <td colspan="2"><div align="center">
    <input type="submit" name="accedi" value="Accedi">
    <input type="reset" value="Resetta"class="button">
    </div></td>
    </tr>
    </table>
    </form>[/HTML]

    Questo è il php
    [PHP]<?php
    // Includo la connessione al database
    require('config.php');

    // Se il modulo viene inviato...
    if(isset($_POST['accedi']))
    {

    // Dati Inviati dal modulo
    $email = (isset($_POST['email'])) ? trim($_POST['email']) : '';    // Metto nella variabile 'email' il dato inviato dal modulo, se non viene inviato dò di default ''
    $password = (isset($_POST['password'])) ? trim($_POST['password']) : '';    // Metto nella variabile 'password' il dato inviato dal modulo, se non viene inviato dò di default ''
    
    
    // Crypto la password e la confronto con quella nel database
    $password = md5($password);
    
    // Controllo l'utente esiste
    $query = mysql_query("SELECT user_id FROM soci WHERE email = '$email' AND password = '$password' and livello = 1");
    
    // Se ha trovato un record
    if(mysql_num_rows($query) == 1)
    {
        // prelevo l'id dal database
        $accedi = mysql_fetch_array($query);
        
        // Creo una variabile di sessione
        $_SESSION['accedi'] = $accedi['user_id'];
        
        // reindirizzo l'utente
        header('Location: area_riservata.php');
        exit;
    }
    // se non esiste da l'errore
    else
        die('L''utente non è stato riconosciuto o non ha i privilegi per accedere all''area riservata');
    

    }
    ?>[/PHP]


  • ModSenior

    Ma come fa ad uscirti sempre pagina bianca? C'è qualcosa che non va...


  • User

    Lo so,infatti per questo chiedo consiglio.
    Per il file della registrazione, adesso provo a scrivere il tutto con la funzione strlen


  • User

    Controllando il file di mirko,mi sono accorto che avevo sbagliato a ricopiare il nome di una variabile.
    Adesso l'ho aggiustato e ho fatto delle prove: sia nel caso in cui riempio tutti i campi,sia nel caso in cui ne lascio unovuoto, come risultato esce una pagina vuota senza grafica o messaggi d'errore e l'inserimento non avviene


  • User Attivo

    Ciao ranz,
    dopo aver inizializzato le variabili PHP scrivi il loro contenuto a video con echo,
    in questo modo capirai quale variabile rimane a null.

    Ciao


  • User

    Allora, ho fatto la prova Mirko.
    Vengono visualizzate tutte, ma non vi è l'inserimento nel database, però se salto volontariamente un campo,non viene visualizzato l'avvertimento del mancato inserimento


  • User

    A questo punto voglio provare a postare il codice della tabella soci dove dovrebbe avvenire l'inserimento, può darsi che l'errore sia lì

    
    CREATE TABLE `soci` (
      `user_id` mediumint(9) NOT NULL auto_increment,
      `nome` varchar(255) NOT NULL,
      `cognome` varchar(255) NOT NULL,
      `giorno` mediumint(9) NOT NULL,
      `mese` mediumint(9) NOT NULL,
      `anno` mediumint(4) NOT NULL,
      `luogo_nascita` varchar(255) NOT NULL,
      `indirizzo` varchar(255) NOT NULL,
      `cap` varchar(5) NOT NULL,
      `citta` varchar(255) NOT NULL,
      `provincia` varchar(255) NOT NULL,
      `email` varchar(255) NOT NULL,
      `password` varchar(12) NOT NULL,
      `verifica_password` varchar(12) NOT NULL,
      `livello` tinyint(4) NOT NULL default '0',
      PRIMARY KEY  (`user_id`)
    ) ENGINE=InnoDB DEFAULT CHARSET=latin1 AUTO_INCREMENT=3 ;
    
    

  • User

    A poco alla volta sto risolvendo i vari problemi.
    Ora riesco a inserire i dati, ma non a far partire l'email,ma non desisto


  • User

    Niente da fare, per il momento non riesco a far partire la mail. Mi potete controllare il codice per favore?
    [PHP]
    //Edito i parametri sottostanti con i dati relativi al sito
    $web_site = '';
    $webmaster = 'Associazione Culturale Calliope';
    $web_mail = '';
    $pass_utente = $_POST['password'];
    $mail_utente = $_POST['email'];
    $nome = $_POST['nome'];
    $cognome =$_POST['nome'];
    $header = "From: ". $web_site . " <" . $web_mail . ">\r\n";
    // Edito l'oggetto e il messaggio
    $subject = "Dettagli registrazione";
    $message = "Gentile $nome $cognome, l'Associazione Culturale Calliope ti ringrazia per esserti registrato su $web_site. La tua richiesta sarà adesso
    esaminata dal consiglio direttivo e in caso di approvazione riceverai l'email specifica. Per usufruire dei nostri servizi devi semplicemente
    inserire questi dati nel login apposito:
    Email: $mail_utente ; Password: $password
    Conserva queste informazioni o meglio ancora stampa questa mail.
    Grazie infinite, $webmaster";

    // Spedisco la mail
    mail($mail_utente, $subject, $message, $header);

    $subject1 = "Richiesta di iscrizione";
    $message1= "Spett.le Associazione Culturale Calliope,
    $nome, $cognome, $email,richiede di poter accedere alla sezione privata del sito";
    mail ($web_mail, $subject1, $message1, $header);
    echo('Registrazione avvenuta, Benvenuto !!!<br /> Le informazioni che ci hai fornito ti sono state spedite via mail.');
    [/PHP]

    Per inciso, le prove le sto realizzandoin privato e nella variabile $web_mail sto provando di volta in volta varie email,ma non funziona.

    Scusate, poichè non conosco nulla per quanto riguarda le sessioni, sapreste indicarmi un tutorial semplice semplice. Mi interessa realizzare delle pagine che solo gli utenti registrati potranno visitare, quindi se ci clicca sopra un utente non registrato, voglio che venga reindirizzato a un'altra pagina