Freischaltmail für Gästebuch

Einklappen
X
 
  • Filter
  • Zeit
  • Anzeigen
Alles löschen
neue Beiträge

  • Freischaltmail für Gästebuch

    Hallo, ich bin neu hier und habe von PHP nicht gerade die Ahnung.

    Ich habe ein PHP-Script gefunden womit Gästebuchdaten per
    Mysql Datenbank gespeichert und abgerufen werden.

    Soweit funktioniert das Ganze cht super.

    Jetzt knuddel ich schon seit "wochen" rum, um den eintragenden Gast
    per Mail zur Bestätigung seines Eintrags zu zwingen.

    Ich habe bereits herausgefunden, dass ich in der SQL Tabelle eine Spalte
    zum erkennen der Freischaltung ( bei mir " aktiv " mit 0 oder 1 )
    und eine Spalte mit einem Code zur Freischaltung ( bei mir " fscode " )

    Leider haben alle Versuche einen Code in mein Script einzufügen
    dass 1. in der Usermail anzeigt: Klicke hier zum freischalten
    noch die Anzeige zu unterdrücken wenn aktiv =0 , noch einen
    Freischaltcode zu generieren, den man abfragen könnte und schon garnicht
    bei absenden der daten in aktiv eine 0 setzten, bei mir funktioniert.

    Kann mit PHPDofi mal jemand helfen?

    Hier der Code, der bisher funktioniert:

    PHP-Code:

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
    "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html>
    <head>
    <script src="/formpruef-de.js" type="text/javascript"></script>
    </head>


    <body onload="startnname()">

    <?php
    include_once('./inc.php');
    include_once(
    './funktionen.php');

    // Variablen auf 0 setzen
    $nname ''$vname =''$ort ''$email ''$beitrag '';
    $t_nname ''$t_ort ''$t_email ''$t_beitrag '';

    // code erstellen, um zu verhindern, dass Spam erfolgt
    $code date('m') * date('Y') * 59 date('d') * 23 47;


    if (isset(
    $_POST['submit'])) {
       
      
    // richtige Form prüfen -> die
      
    if (strlen($_POST['nname'])  > 50 ) die ('Manipulation') ;
      if (
    strlen($_POST['vname'])  > 50 ) die ('Manipulation') ;
      if (
    strlen($_POST['ort'])    > 50 ) die ('Manipulation') ;
      if (
    strlen($_POST['email'])  > 50 ) die ('Manipulation') ;
     
      if (!isset(
    $_POST['code']) || $_POST['code'] != $code) die('Mailcode fehlt!');
       
      
    // Tags entfernen
      
    $nname   strtr(trim(strip_tags($_POST['nname'])),'@\/','   ');
      
    $vname   strtr(trim(strip_tags($_POST['vname'])),'@\/','   ');
      
    $ort     strtr(trim(strip_tags($_POST['ort'])),'@\ ','   ');
      
    $email   trim(strip_tags($_POST['email']));    
      
    $beitrag strtr(trim(strip_tags($_POST['beitrag'])),'@\/','   ');
       
      
    // Lange Wörter (>50) zwangstrennen, um richtige Darstellung zu erhalten.
      
    $beitrag wordwrap($beitrag50' '1);
      
    // doppelte Leerstellen entfernen
      
    $beitrag str_replace('  '' '$beitrag);
         
      
    // pruefen ob alle Variablen richtig
      
    if ( $nname == "" )     { $t_nname "Bitte Nachname angeben!" ; }
      if ( 
    $nname == $vname ) { $t_nname "Das kann nicht sein, Vor- und Nachname!" ; }
      if ( 
    $ort == "" )       { $t_ort   "Bitte Ort angeben!" ; }
      if ( 
    $email == "" )     { $t_email "" ; }
      else {
        if(
    check_email($email)) { $t_email "" ; }
        else { 
    $temail "E-Mail nicht richtig!" ; }
      }
      if ( 
    $beitrag == "" ) { $t_beitrag "Bitte Beitrag schreiben!" ; }

      
    // wenn i.O., Mails senden und eintragen in DB
      
    if ( $t_nname == "" && $t_ort == "" && $t_beitrag == "" && $t_email == "" ) {

        
    $headers  "MIME-Version: 1.0\n";
        
    $headers .= "Content-Type: text/plain; charset=iso-8859-1\n";
        
    $headers .= "From:meine Adresse Gaestebuch <info@meine Adresse.de>\n";
        
    $headers .= "Reply-To: info@meine Adresse.de\n";
        
    $headers .= "X-Sender-IP:".$REMOTE_ADDR."\n";
        
    $headers .= "X-Mailer:PHP/".phpversion();

        
    $webmaster "info@meine Adresse.de";
        
    $betreff "Gaestebucheintrag";
        
    $kopf1 "Folgender Eintrag erfolgte:\n\n";
        
    $eintrag "Nachname: ".$nname."\nVorname: ".$vname."\nOrt: ".$ort."\nEMail: ".$email."\n\n".$beitrag."\n";
        
    $loeschlink "\n\nLöschen: http://www.meine Adresse.de/gaestebuch/gaestebuch_loe.php\n\n";
        
    $text1 $kopf1.$eintrag.$loeschlink;

        @
    mail($webmaster,$betreff,$text1,$headers);

        if (
    $email !=""){
          
    $kopf2 "Sie haben in unser Gästebuch folgenden Eintrag vorgenommen:\n\n";
          
    $fuss2 "\n\nVielen Dank für Ihren Eintrag. Zum freischalten bitte den Link anklicken.\nAdmin\nwww.meine Adresse.de";
          
    $text2 $kopf2.$eintrag.$fuss2;
          @
    mail($email,$betreff,$text2,$headers);
        }

        
    // Eintraege an DB gaestebuch senden
        
    $query "INSERT into gaestebuch (vname,nname,ort,email,beitrag,aktiv,fscode)
        VALUES('
    $vname','$nname','$ort','$email','$beitrag')";
        
    $result mysql_query($query$conn) or mysql_die();


        
    // Felder leeren
        
    $nname "" $vname "" $ort "" $email "" $beitrag "" ;
      }
    }
    // submit abgeschlossen, es folgt die eigentliche Seite ---------------

    echo '
    <form method="post" action="'
    .htmlspecialchars($_SERVER['PHP_SELF']).'" name="meldung">
    <table width="100%" summary="Eingabeformular">
        <colgroup>
            <col width="150" />
            <col />
        </colgroup>
        <tr>
            <td>Nachname</td>
            <td>
                <input type="text" name="nname" size="40" maxlength="50" tabindex="1" value="'
    .$nname.'" />
                <span class="rot"><strong>'
    .$t_nname.' </strong></span>
            </td>
        </tr>
        <tr>
            <td>Vorname</td>
            <td><input type="text" name="vname" size="40" maxlength="50" tabindex="2" value="'
    .$vname.'" /></td>
        </tr>
        <tr>
            <td>Ort</td>
            <td>
                <input type="text" name="ort" size="40" maxlength="50" tabindex="3" value="'
    .$ort.'" />
                <span class="rot"><strong>'
    .$t_ort.' </strong></span>
            </td>
        </tr>
        <tr>
            <td>E-Mail</td>
            <td>
                <input type="text" name="email" size="40" maxlength="50" tabindex="4" value="'
    .$email.'" />
                <span class="rot"><strong>'
    .$t_email.' </strong></span>
            </td>
        </tr>
        <tr>
            <td>Beitrag</td>
            <td>
                <textarea rows="9" name="beitrag" cols="60" tabindex="5">'
    .$beitrag.'</textarea>
                <br /><span class="rot"><strong>'
    .$t_beitrag.' </strong></span>
            </td>
        </tr>
        <tr>
            <td> </td>
            <td>
                <input type="hidden" id="code" name="code" value="'
    .$code.'" />
                <input class="norm" type="submit" name="submit" value="abschicken" tabindex="6" />
            </td>
        </tr>
    </table>
    </form>
    '
    ;
    ?>

    <h4>Gästebucheintragungen</h4>

    <?php
    // Verbindung mit DB fuer Eintragungen anzeigen
    $query "SELECT *, DATE_FORMAT(tstamp,'%d.%m.%y') AS tstamp_f FROM gaestebuch ORDER BY tstamp DESC";
    $result mysql_query($query,$conn);
    $num mysql_num_rows($result);

    for (
    $i 0$i $num$i++){
      
    $row mysql_fetch_array($result);
      echo 
    '
    <table width="100%">
      <colgroup>
        <col width="60" />
        <col />    
        <col width="50" />     
        <col width="150" />    
      </colgroup>
      <tr>
        <td >Name:</td>
        <td>'
    .$row['vname'].' '.$row['nname'].'</td>
        <td>Ort:</td>
        <td>'
    .$row['ort'].'</td>
      </tr>
      <tr>
        <td>Mail:</td>
        <td>'
    .$row['email'].'</td>
        <td>Date:</td>
        <td>'
    .$row['tstamp_f'].'</td>
      </tr>
    </table>
    <p class="bgweiss">'
    .nl2br($row['beitrag']).'</p>
      '
    ;
    }
    mysql_close($conn);
    ?>
       <td>'.$row['tstamp_f'].'</td>
      </tr>
    </table>
    <p class="bgweiss">'.nl2br($row['beitrag']).'</p>
      ';
    }
    mysql_close($conn);
    ?>
    Vielen Dank für die Hilfe,

    Gruß Markus
Lädt...
X