php.de

Zurück   php.de > Webentwicklung > PHP Einsteiger > PHP Tipps 2009

 
 
LinkBack Themen-Optionen Thema bewerten
Alt 25.04.2009, 21:26  
Neuer Benutzer
 
Registriert seit: 24.04.2009
Beiträge: 20
fuckinghot19 befindet sich auf einem aufstrebenden Ast
Standard [Erledigt]Brauche Hilfe beim Script Debuggen

Hallo
Also ich brauche dringend Hilfe.
Und zwar habe ich ein Script geschrieben auf das die leute verbinden.
Ausgegeben werden dann bestimmte sätze die man sich aus einer datenbank holt.
Jetzt will ich aber nicht dass die Leute immer das selbe lesen.
Also habe ich die einträge mit einer ansteigenden id versehen und bei jeden besuch wird am ende ein cookie gesetzt der die höchste id beinhaltet.
dieser cookie wird am anfang ausgelesen und ab da sollten dann alle einträge angezeigt werden.
Also die ID im cookie ist zB 12 und beim nächsten besuch gibt es bereits 14 einträge werden die letzten 2 einträge angezeigt und der cookie in 14 geändert.
Tja so weit so gut
Jetzt werden mir aber alle einträge angezeigt....
Hier mal das script(ich hab versucht es selber zu debuggen und ein den code gekennzeichnet wo ich den fehler vermute).
PHP-Code:
<?php
include 'connect.php';
$id=$_COOKIE['command'];
$sql "SELECT
    *
FROM
    command
WHERE
id > '$id'
"
;
$result mysql_query($sql);
if (!
$result) {
    die (
'Mysql Error: '.mysql_error());
};
while(
$row mysql_fetch_object($result)) {
echo 
$row->command;

};                                                
//ab hier ist ein fehler
$sql3="SELECT MAX(id) AS id FROM command";
$result3 mysql_query($sql3);
if (!
$result3) {
    die (
'Mysql Error: '.mysql_error());
};
while(
$row mysql_fetch_object($result)) {
$rrrrrr=$row->id;
setcookie("command""$rrrrrr");
}
$ip $_SERVER['REMOTE_ADDR'];

                                                
//ab hier geht wieder alles
$sql1="INSERT INTO stat (bots , logtime)
VALUES(
'$ip',
now()
)"
;
$result1 mysql_query($sql1);
if (!
$result1) {
    die (
'Mysql Error: '.mysql_error());
};


echo 
"<br><br>".$_COOKIE['command'];
echo 
'<br>'.$rrrrrr;

?>
cookie ist keiner gesetzt daher vermute ich dass er die max(id) nicht findet und die querry leer bleibt.
und somit auch der cookie leer ist

Vielen Dank im vorraus
mfg

Geändert von fuckinghot19 (25.04.2009 um 23:20 Uhr).
fuckinghot19 ist offline  
Sponsor Mitteilung
PHP Code Flüsterer

Registriert seit: 21.08.2005
Beiträge: 4682
PHP-Kenntnisse:
Fortgeschritten

Alt 25.04.2009, 21:32  
Erfahrener Benutzer
 
Benutzerbild von David
 
Registriert seit: 05.09.2007
Beiträge: 5.044
David wird schon bald berühmt werden
Standard

Warum rufst Du den Maximalwert mit einer weiteren Abfrage ab? (unnötig und Raum für race condition)
Du hast den Wert doch bereits nach der ersten while-Schleife. Wenn Du sicher gehen willst, dass der letzte Wert auch wirklich der Maximalwert ist, kannst Du noch ein ORDER BY id an die erste Abfrage anhängen.

Du kannst keinen Cookie mehr setzen, nachdem bereits per echo o.ä. etwas ausgegeben wurde.
Zum Debuggen error_reporting auf E_ALL und ggf. display_errors auf On setzen. Auf dem Entwicklungsserver am besten dauerhaft in der php.ini
David ist offline  
Alt 25.04.2009, 21:32  
Erfahrener Benutzer
 
Benutzerbild von JanM
 
Registriert seit: 22.12.2003
Beiträge: 788
PHP-Kenntnisse:
Fortgeschritten
JanM ist zur Zeit noch ein unbeschriebenes Blatt
Standard

Mach doch gernell auch mal darunter:
PHP-Code:
echo mysql_error(); 
__________________

Statistik
JanM ist offline  
Alt 25.04.2009, 21:50  
Neuer Benutzer
 
Registriert seit: 24.04.2009
Beiträge: 20
fuckinghot19 befindet sich auf einem aufstrebenden Ast
Standard

Ok vielen Dank
Also jetzt mal zur Sicherheit.
Was würdet ihr mir empfehlen wie ich den Cookie setze.
Ich hätte mir gedacht eine global variable zu setzen dann eine weiterleitung zu machen und dort dann den cookie zu setzen.
Is das klug??
Wobei es besser wäre wenn ich den fetch-befehl einfach auf die andre seite verlege.
Vielen Dank für die schnelle Hilfe

Geändert von fuckinghot19 (25.04.2009 um 21:57 Uhr).
fuckinghot19 ist offline  
Alt 25.04.2009, 22:01  
Erfahrener Benutzer
 
Benutzerbild von David
 
Registriert seit: 05.09.2007
Beiträge: 5.044
David wird schon bald berühmt werden
Standard

Angenommen, Du könntest durch einen "globale Variable" Daten über eine Weiterleitung hinweg "retten" ...wozu bräuchtest Du dann noch cookies?

Ist es wichtig, dass die ältesten Einträge (mit der kleinsten id) ganz oben stehen? Wenn nicht, wenn die Reihenfolge auch genau umgekehrt sein kann, wäre eine mögliche Lösung
PHP-Code:
<?php
require 'connect.php';
$id=isset($_COOKIE['command']) ? (int)$_COOKIE['command'] : 0;

$sql "
  SELECT
    `id`, `command`
  FROM
    command
  WHERE
    id > $id
  ORDER BY
    id DESC
"
;
$result mysql_query($sql) or die ('Mysql Error: '.mysql_error());
if ( 
false===($row=mysql_fetch_array($resultMYSQL_ASSOC)) ) {
  echo 
'keine (weiteren) Datensätze vorhanden';
}
else {
  
setcookie("command"$row['id']);
  do {
    echo 
htmlspecialchars($row['command']), "<br />\n";
  } while (
false===($row=mysql_fetch_array($resultMYSQL_ASSOC)) );
}
David ist offline  
Alt 25.04.2009, 22:48  
Neuer Benutzer
 
Registriert seit: 24.04.2009
Beiträge: 20
fuckinghot19 befindet sich auf einem aufstrebenden Ast
Standard

Zitat:
Zitat von David Beitrag anzeigen
Angenommen, Du könntest durch einen "globale Variable" Daten über eine Weiterleitung hinweg "retten" ...wozu bräuchtest Du dann noch cookies?

Ist es wichtig, dass die ältesten Einträge (mit der kleinsten id) ganz oben stehen? Wenn nicht, wenn die Reihenfolge auch genau umgekehrt sein kann, wäre eine mögliche Lösung
PHP-Code:
<?php
require 'connect.php';
$id=isset($_COOKIE['command']) ? (int)$_COOKIE['command'] : 0;

$sql "
  SELECT
    `id`, `command`
  FROM
    command
  WHERE
    id > $id
  ORDER BY
    id DESC
"
;
$result mysql_query($sql) or die ('Mysql Error: '.mysql_error());
if ( 
false===($row=mysql_fetch_array($resultMYSQL_ASSOC)) ) {
  echo 
'keine (weiteren) Datensätze vorhanden';
}
else {
  
setcookie("command"$row['id']);
  do {
    echo 
htmlspecialchars($row['command']), "<br />\n";
  } while (
false===($row=mysql_fetch_array($resultMYSQL_ASSOC)) );
}

Danke das is perfeckt.
Genau das was ich brauche

Ok jetzt gibt er mir nur den letzten aus
aber er soll auch die davor ausgeben
wie mach ich das??

Geändert von fuckinghot19 (25.04.2009 um 22:55 Uhr).
fuckinghot19 ist offline  
Alt 25.04.2009, 23:09  
Erfahrener Benutzer
 
Registriert seit: 28.05.2008
Beiträge: 2.094
PHP-Kenntnisse:
Fortgeschritten
rudygotya ist einfach richtig nettrudygotya ist einfach richtig nettrudygotya ist einfach richtig nettrudygotya ist einfach richtig nettrudygotya ist einfach richtig nett
Standard

Hauch dem Keks Leben ein?
string $name [, string $value [, int $expire= 0....
Zitat:
expire Der Zeitpunkt, an dem das Cookie ungültig wird. Dies ist ein Unix Timestamp, also die Anzahl Sekunden seit Beginn der Epoche. Mit anderen Worten, Sie werden diesen Wert wahrscheinlich mittels der Funktion time() plus der Anzahl Sekunden bis zum gewünschten Ablauf des Cookies setzen. Sie könnten aber auch mktime() verwenden. time()+60*60*24*30 wird das Cookie in 30 Tagen ablaufen lassen. Hat der Parameter den Wert 0 oder ist er nicht gesetzt, verfällt das Cookie am Ende der Session (wenn der Browser geschlossen wird).
gruß
__________________
++++ Wieder einer ins Netz gegangen: Phishers Fritz zufrieden ++++
Blog
rudygotya ist gerade online  
Alt 25.04.2009, 23:14  
Erfahrener Benutzer
 
Benutzerbild von David
 
Registriert seit: 05.09.2007
Beiträge: 5.044
David wird schon bald berühmt werden
Standard

Zitat:
while (false===($row=mysql_fetch_array($result, MYSQL_ASSOC)) );
copy&paste Fehler. Es muss false!==($row=... heißen.
David ist offline  
Alt 25.04.2009, 23:14  
Neuer Benutzer
 
Registriert seit: 24.04.2009
Beiträge: 20
fuckinghot19 befindet sich auf einem aufstrebenden Ast
Standard

hat sich erledigt

Geändert von fuckinghot19 (25.04.2009 um 23:19 Uhr).
fuckinghot19 ist offline  
Alt 25.04.2009, 23:19  
Neuer Benutzer
 
Registriert seit: 24.04.2009
Beiträge: 20
fuckinghot19 befindet sich auf einem aufstrebenden Ast
Standard

Zitat:
Zitat von David Beitrag anzeigen
copy&paste Fehler. Es muss false!==($row=... heißen.
danke danke danke



Super schnelle antworten.
Und keine Beleidigungen ^^

danke euch
fuckinghot19 ist offline  
 


Themen-Optionen
Thema bewerten
Thema bewerten:

Forumregeln
Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are an
Gehe zu

Ähnliche Themen
Thema Autor Forum Antworten Letzter Beitrag
Hilfe! Ich will debuggen! shor PHP Tipps 2009 7 04.04.2009 15:42
[Erledigt] Brauche Hilfe bei einem Script! djscaleo PHP Tipps 2008 14 01.11.2008 13:23
Brauche bitte Hilfe mit CURL (cookies). Chaox PHP-Fortgeschrittene 2 18.02.2008 08:33
ich brauch hilfe bei meinem PHP Script cwillingshofer PHP Tipps 2007 3 30.07.2007 08:52
Ich brauche eure Hilfe beim rechnen... GELight PHP Tipps 2006 6 07.04.2006 14:20
Bitte um Hilfe: Fehler im Script ?!? PHP Tipps 2005 6 23.05.2005 21:46
brauche dringend hilfe für ein login script PHP Tipps 2005 17 22.05.2005 21:56
Hilfe für Script (ähnlich wie Clanwar) PHP Tipps 2005 10 18.05.2005 20:28
[Erledigt] Hilfe bei Download Verwaltungs Script PHP Tipps 2005 8 04.05.2005 10:29
Script zum ändern einer RDF Datei ! Brauche HILFE! PHP Tipps 2004-2 3 06.12.2004 09:21
Brauche Script Beitragsarchiv 11 27.11.2004 00:21
Brauche Dringend Hilfe bei einem Script !!! PHP-Fortgeschrittene 13 20.10.2004 23:17
brauche hilfe bei upload script... PHP Tipps 2004 2 14.08.2004 14:32

Besucher kamen über folgende Suchanfragen bei Google auf diese Seite
mysql_fetch_array debuggen

Alle Zeitangaben in WEZ +2. Es ist jetzt 19:40 Uhr.




Powered by vBulletin® Version 3.7.2 (Deutsch)
Copyright ©2000 - 2012, Jelsoft Enterprises Ltd.
Search Engine Optimization by vBSEO 3.2.0
Aprilia-Forum, Aquaristik-Forum, Liebeskummer-Forum, Zierfisch-Forum, Geizkragen-Forum