Zum Inhalt springen

Problem mit Gästebuch...!


Empfohlene Beiträge

Hi,

ich hab da nen Problem. Ich will, dass immer nur 6 Gästebucheinträge auf einer

Seite angezeigt werden. Also, hab ich das Script nen bissl modifiziert.

Funktioniert aber net richtig. Weiß net warum. Irgendwie passiert da gar nix...:(!

Hier mal der Code:


<?php
$host = "xxx";
$name = "xxx";
$passwort = "xxx";

$sql = mysql_connect($host, $name, $passwort);
$dbname = "xxx";
mysql_select_db($dbname);

if ($seite < 1) {
$seite = 1;
}

$seitenanzahl = $seite * 6;
$seitenanzahlminus = $seitenanzahl - 6;

$res = mysql_query( "select count(*) from `basti-wehr_gaestebuch`" );
$row = mysql_fetch_row($res);
$anzahl = $row[0];

$anfrage = mysql_query( "SELECT id,name,email,homepage,ort,nachricht FROM `basti-wehr_gaestebuch` ORDER BY id DESC LIMIT $seitenanzahlminus, $seitenanzahl" )
or die ( "Konnte Gästebuch nicht anzeigen: ".mysql_error() );
while ($datensatz = mysql_fetch_object($anfrage) AND $i <= 15){
$i = $i + 1;
print "<table width=\"100%\" border=\"0\" cellpadding=\"0\" cellspacing=\"1\">";
print "<tr>";
print "</tr>";
print "<tr>";
print "<td width=\"11%\"><strong>Name:</strong></td>";
print "<td width=\"32%\">$datensatz->name</td>";
print "<td width=\"18%\"><strong>aus dem Ort:</strong></td>";
print "<td width=\"39%\">$datensatz->ort</td>";
print "</tr>";
print "<tr>";
print "<td><strong>E-Mail:</strong></td>";
print "<td><a href=\"mailto:$datensatz->email\">$datensatz->email</a></td>";
print "<td><strong>Homepage:</strong></td>";
print "<td><a href=\"$datensatz->homepage\">$datensatz->homepage</a></td>";
print "</tr>";
print "<tr>";
print "<td colspan=\"4\"><strong>Nachricht:</strong></td>";
print "</tr>";
print "<tr>";
print "<td colspan=\"4\"><font color=\"#333333\">$datensatz->nachricht</font></td>";
print "</tr>";
print "</table><br>";
}

$iMaxSites = ceil( $anzahl / 6);
for ( $i = 0; $i < $iMaxSites;) {
$i++;
echo "<a href='gaestebuch.php?seite=". $i ."'>[Seite ". $i . "]</a> ";
}
mysql_close($sql);
?>
[/PHP]

Das Gästebuch ist hier: http://basti-wehr.sebastian-muth.de/htm/guestbook.php

Ich hoffe, dass mir einer helfen kann. Schon mal Danke im Vorraus!

Gruß

Sebastian

Link zu diesem Kommentar
Auf anderen Seiten teilen

So wie ich es geschrieben habe.


<?php
$host = "xxx";
$name = "xxx";
$passwort = "xxx";

$sql = mysql_connect($host, $name, $passwort);
$dbname = "xxx";
mysql_select_db($dbname);

if ($_GET['seite'] < 1) {
$_GET['seite'] = 1;
}

$seitenanzahl = $_GET['seite'] * 6;
$seitenanzahlminus = $seitenanzahl - 6;

$res = mysql_query( "select count(*) from `basti-wehr_gaestebuch`" );
$row = mysql_fetch_row($res);
$anzahl = $row[0];

$anfrage = mysql_query( "SELECT id,name,email,homepage,ort,nachricht FROM `basti-wehr_gaestebuch` ORDER BY id DESC LIMIT $seitenanzahlminus, $seitenanzahl" )
or die ( "Konnte Gästebuch nicht anzeigen: ".mysql_error() );
while ($datensatz = mysql_fetch_object($anfrage) AND $i <= 15){
$i = $i + 1;
print "<table width=\"100%\" border=\"0\" cellpadding=\"0\" cellspacing=\"1\">";
print "<tr>";
print "</tr>";
print "<tr>";
print "<td width=\"11%\"><strong>Name:</strong></td>";
print "<td width=\"32%\">$datensatz->name</td>";
print "<td width=\"18%\"><strong>aus dem Ort:</strong></td>";
print "<td width=\"39%\">$datensatz->ort</td>";
print "</tr>";
print "<tr>";
print "<td><strong>E-Mail:</strong></td>";
print "<td><a href=\"mailto:$datensatz->email\">$datensatz->email</a></td>";
print "<td><strong>Homepage:</strong></td>";
print "<td><a href=\"$datensatz->homepage\">$datensatz->homepage</a></td>";
print "</tr>";
print "<tr>";
print "<td colspan=\"4\"><strong>Nachricht:</strong></td>";
print "</tr>";
print "<tr>";
print "<td colspan=\"4\"><font color=\"#333333\">$datensatz->nachricht</font></td>";
print "</tr>";
print "</table><br>";
}

$iMaxSites = ceil( $anzahl / 6);
for ( $i = 0; $i < $iMaxSites;) {
$i++;
echo "<a href='gaestebuch.php?seite=". $i ."'>[Seite ". $i . "]</a> ";
}
mysql_close($sql);
?>
[/php]

Frank

Link zu diesem Kommentar
Auf anderen Seiten teilen


if ($seite < 1) {
$seite = 1;
}

$seitenanzahl = $seite * 6;
$seitenanzahlminus = $seitenanzahl - 6;
[/PHP]

Hier hast du deine Variable Seite, die du dir wahrscheinlich aus dem REQUEST holen willt, ist das richtig.

Wenn der Server nicht dafür eingestellt ist, kann er die Variable nicht empfangen und du musst sie aus dem Array $GET auslesen!

Versuch mal in der if Bedingung $seite mit $GET['seite'] zu ersetzen!

Oder lass dir überhaupt mal seite ausgeben, um zu sehen, ob die Seite übergeben wird!

Edit: War wohl zu spät

Link zu diesem Kommentar
Auf anderen Seiten teilen

Danke.

Funktioniert jetzt...:)!

Gruß

Sebastian

zur Erklärung:

da die Variabel 'seite' in der url eines Links oder in der Adressezeile erscheint, musst du diese mit $_GET['seite'] ansprechen. (Da die Variable dann ein sog. GET Parameter ist).

Variablen die du durch Formulare erhälst, werden als POST variablen bezeichnet, da sie (sofern method='post' gesetzt ist) per Absenden button "gepostet" werden. Diese sind dann im Array $_POST zu finden.

Weitere details dazu findest du im Google unter dem Stichwort "register globals"

Link zu diesem Kommentar
Auf anderen Seiten teilen

Dein Kommentar

Du kannst jetzt schreiben und Dich später registrieren. Wenn Du ein Konto hast, melde Dich jetzt an, um unter Deinem Benutzernamen zu schreiben.

Gast
Auf dieses Thema antworten...

×   Du hast formatierten Text eingefügt.   Formatierung wiederherstellen

  Nur 75 Emojis sind erlaubt.

×   Dein Link wurde automatisch eingebettet.   Einbetten rückgängig machen und als Link darstellen

×   Dein vorheriger Inhalt wurde wiederhergestellt.   Editor leeren

×   Du kannst Bilder nicht direkt einfügen. Lade Bilder hoch oder lade sie von einer URL.

Fachinformatiker.de, 2024 by SE Internet Services

fidelogo_small.png

Schicke uns eine Nachricht!

Fachinformatiker.de ist die größte IT-Community
rund um Ausbildung, Job, Weiterbildung für IT-Fachkräfte.

Fachinformatiker.de App

Download on the App Store
Get it on Google Play

Kontakt

Hier werben?
Oder sende eine E-Mail an

Social media u. feeds

Jobboard für Fachinformatiker und IT-Fachkräfte

×
×
  • Neu erstellen...