DevProTalk

Forumi IT profesionalaca
web development, web design, e-business, SEO


Idite nazad   DevProTalk > Web development i web aplikacije > PHP
Želite da se reklamirate ekskluzivno na ovoj poziciji? Javite se

PHP PHP aplikacije, Smarty, PEAR

Odgovori
 
Alati teme Način prikaza
Staro 14. 11. 2005.   #1
bluesman
Goran Pilipović
Sir Write-a-Lot
 
Avatar bluesman
 
Datum učlanjenja: 18.05.2005
Lokacija: Beograd
Poruke: 5.450
Hvala: 288
1.247 "Hvala" u 446 poruka
bluesman je osoba koju treba slušatibluesman je osoba koju treba slušatibluesman je osoba koju treba slušatibluesman je osoba koju treba slušatibluesman je osoba koju treba slušatibluesman je osoba koju treba slušatibluesman je osoba koju treba slušatibluesman je osoba koju treba slušatibluesman je osoba koju treba slušati
Pošaljite ICQ poruku za bluesman
Default Debug PHP scriptova

Kako radite debug?

Mislim na onaj naprostiji, slozeniji i najkomplikovaniji. Imate neke alate ili pichite sa echo, print_r(), var_dump() ?
__________________
Goran Pilipović a.k.a. Ugly Fingers Bradley f.k.a. bluesman
I don't always know what I'm talking about but I know I'm right!
bluesman je offline   Odgovorite uz citat
Staro 14. 11. 2005.   #2
srdjevic
profesionalac
Professional
 
Datum učlanjenja: 15.06.2005
Lokacija: Chicago IL, USA
Poruke: 209
Hvala: 12
12 "Hvala" u 11 poruka
srdjevic is on a distinguished road
Default

Moj slucaj:

Za najprostije provere dok pisem kod koristim:
function dbg($var, $dontDie = false) {
echo '<pre>Vartype: ' . gettype($var) . "\n" . htmlentities( print_r($var, true) ) . '</pre>';
if ( !$dontDie ) exit;
}

A za prijavu gresaka imam error_handler-a koji pljuje (na ekran, u bazu, na mail, u xml, gde mu kazem, tj. kako ga podesim) var_dump, backtrace i sva cuda kojih sam mogao da se setim.
srdjevic je offline   Odgovorite uz citat
Staro 14. 11. 2005.   #3
Petar Marić
Python Ambassador
Master
 
Avatar Petar Marić
 
Datum učlanjenja: 06.06.2005
Lokacija: Novi Sad
Poruke: 602
Hvala: 28
27 "Hvala" u 17 poruka
Petar Marić će postati "faca" uskoro
Pošaljite ICQ poruku za Petar Marić
Lightbulb

IMHO, jedan od definitivno boljih metoda debugovanja php-a sam video kod Ilije.
Nešto jako slično gorepomenutom sistemu je danas dobio i django(primer 404 i 500 greške).
__________________
Python Ambassador of Serbia
Petar Marić je offline   Odgovorite uz citat
Staro 14. 11. 2005.   #4
Ilija Studen
Direktor Kombinata
Invented the damn thing
 
Avatar Ilija Studen
 
Datum učlanjenja: 07.06.2005
Poruke: 2.669
Hvala: 44
119 "Hvala" u 64 poruka
Ilija Studen će postati "faca" uskoroIlija Studen će postati "faca" uskoro
Default

To što je Petar video je prikaz izuzetka koji nije uhvaćen (predviđen). U PHP5 se može definisati funkcija (pomoću set_exception_handler()) koja hvata te izuzetke i obrađuje ih (u suprotnom se dobije klasičan Fatal error). Moja implementacija te funkcije prikazuje informacije o izuzetku (fajl, linija, dodatna polja...), trace i stanje sistemskih promenljivih ($_GET, $_POST, $_SESSION, $_COOKIE...). Ništa revolucionarno, ali sam se preporodio kad sam to napravio...

Za "lokalizovanje" greške koristim die() i var_dump() (tačnije, varijaciju na isti, ali poenta nije bitnije izmenjena). Iako Zend Studio ima ugrađen debugger nisam se navikao na njega (nisam se preterano ni trudio). Čekićanje, ali radi posao...
Ilija Studen je offline   Odgovorite uz citat
Staro 15. 11. 2005.   #5
dinke
Super Moderator
Invented the damn thing
 
Avatar dinke
 
Datum učlanjenja: 06.06.2005
Poruke: 2.371
Hvala: 370
701 "Hvala" u 194 poruka
dinke je pravi dragi kamendinke je pravi dragi kamendinke je pravi dragi kamendinke je pravi dragi kamendinke je pravi dragi kamendinke je pravi dragi kamendinke je pravi dragi kamen
Default

echo i var_dump mostly, Zend Studio kad prigusti
__________________
Caught in a Web|Blogodak
With great power comes great responsibility!
dinke je offline   Odgovorite uz citat
Staro 15. 11. 2005.   #6
oliver
expert
Expert
 
Avatar oliver
 
Datum učlanjenja: 16.06.2005
Lokacija: Novi Sad
Poruke: 580
Hvala: 1
0 "Hvala" u 0 poruka
oliver is on a distinguished road
Pošaljite ICQ poruku za oliver Pošaljite poruku preko Skype™ za oliver
Default

PHP kôd:
function wtf($perosarin) {
     echo 
"<pre>";
     
var_dump($perosarin);
     echo 
"</pre>";

radi pos'o
__________________

oliver je offline   Odgovorite uz citat
Staro 16. 11. 2005.   #7
bluesman
Goran Pilipović
Sir Write-a-Lot
 
Avatar bluesman
 
Datum učlanjenja: 18.05.2005
Lokacija: Beograd
Poruke: 5.450
Hvala: 288
1.247 "Hvala" u 446 poruka
bluesman je osoba koju treba slušatibluesman je osoba koju treba slušatibluesman je osoba koju treba slušatibluesman je osoba koju treba slušatibluesman je osoba koju treba slušatibluesman je osoba koju treba slušatibluesman je osoba koju treba slušatibluesman je osoba koju treba slušatibluesman je osoba koju treba slušati
Pošaljite ICQ poruku za bluesman
Default

ja sam pravio neku funkciju bprint_f koja radi slično kao print_f sa tom razlikom što prikazuje tipove i veličine podaka pa sve u boji

output izgleda otprilike ovako:
Kôd:
'sms' [array 5]:
    (
    'instance': CH9229 [string 6]
    'username': dad10065 [string 8]
    'password': 7PfRv4kU [string 8]
    'command' [array 2]:
        (
        0: WEBSUBSCRIBE [string 12]
        'attr' [array 2]:
            (
            'a': name [string 4]
            'status': ok [string 2]
            )
        )
    'parameters' [array 4]:
        (
        'attr' [array 1]:
            (
            'b': sisa [string 4]
            )
        'receiver' [array 2]:
            (
            0: +41795657570 [string 12]
            'attr' [array 1]:
                (
                'operator': swisscom [string 8]
                )
            )
        'service': DADAMOBILE [string 10]
        'operator': swisscom [string 8]
        )
    )
gura sve što mu poturiš, od bool pa do object. Naravno, u pitanju je rekurzija.
__________________
Goran Pilipović a.k.a. Ugly Fingers Bradley f.k.a. bluesman
I don't always know what I'm talking about but I know I'm right!
bluesman je offline   Odgovorite uz citat
Staro 17. 11. 2005.   #8
ivanhoe
Ivan Dilber
Sir Write-a-Lot
 
Avatar ivanhoe
 
Datum učlanjenja: 18.10.2005
Lokacija: Bgd
Poruke: 5.320
Hvala: 104
2.344 "Hvala" u 583 poruka
ivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svima
Pošaljite poruku preko Skype™ za ivanhoe
Default

debug_backtrace zna da bude koristan kad treba provaliti redosled kojim se stiglo do te tacke, recimo kad provaljujes tudj kod pa ti nije jasna logika...

a inace print_r i echo obicno odrade posao...
ivanhoe je offline   Odgovorite uz citat
Odgovori


Alati teme
Način prikaza

Pravila pisanja
Možete ne započinjati nove teme
Možete ne slati odgovore
Možete ne slati priloge
Možete ne izmeniti svoje poruke
vB kôd je Uključen
Smajliji su Uključen
[IMG] kod je Uključen
HTML kôd je Isključen
Pogledajte forum

Slične teme
Tema Početna poruka teme Forum Odgovori Poslednja poruka
Zend Studio debug problem c_shark PHP 0 26. 04. 2010. 13:14
PHP DEbug platforma Pedja PHP 0 08. 08. 2007. 00:21
HTTP debug alati - Fiddler i HttpSpy DejanVesic Web aplikacije, web servisi i software 4 22. 10. 2005. 04:39


Vreme je GMT +2. Trenutno vreme je 01:52.


Powered by vBulletin® Verzija 3.6.8
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Copyright © DevProTalk. All Rights Reserved.
Mišljenja, saveti, izjave, ponude ili druge informacije ili sadržaji nastali na Sajtu su vlasništvo onoga ko ih je kreirao, a ne DevProTalk.com, tako da ne morate da se oslanjate na njih.
Autori poruka su jedini odgovorni za ovakve sadržaje. DevProTalk.com ne garantuje tačnost, kompletnost ili upotrebnu vrednost informacija, stavova, saveta ili datih izjava. Ne postoje uslovi pod kojima bi mi bili odgovorni za štetu ili gubitak koji je posledica bilo čijeg oslanjanja na nepouzdane informacije, ili bilo kakve informacije nastale kroz komunikaciju između registrovanih članova.
Web sajt može sadržavati linkove na druge web sajtove na Internetu ili neke druge sadržaje. Ne kontrolišemo niti podržavamo te druge web sajtove, niti smo pregledali bilo kakve sadržaje na takvim sajtovima. Mi nećemo biti odgovorni za legalnost, tačnost ili prikladnost bilo kog sadržaja, oglasa, proizvoda, usluga ili informacije lociranim na ili distribuiranih kroz druge web sajtove, niti za bilo kakvu štetu nastalu kao posledica takvih informacija. DevProTalk.com drži i čuva druga prava vlasništva na web sajtu. Web sajt sadrže materijale zaštićene copyright-om, zaštitne znakove i druge informacije o pravu vlasništva ili softver. Članovi mogu poslatu informacije zaštićene pravima vlasništva njihovih nosilaca i ona ostaju zaštićena bez obzira da li su oni koji prenose te informacije to naveli ili ne. Osim informacija koje su u javnom vlasništvu ili za koje dobijete dozvolu, nemate pravo da kopirate, modifikujete ili na bilo koji način menjate, objavljujete, prenosite, distribuirate, izvršavate, prikazujete ili prodajte bilo koju informaciju zaštićenu pravima vlasništva. Slanjem informacija ili sadržaja na bilo koji deo DevProTalk.com, Vi automatski dozvoljavate i predstavljate garanciju da imate pravo da dozvolite DevProTalk.com ili članovima DevProTalk.com bespovratnu, kontinualnu, neograničenu, globalnu dozvolu da koriste, kopiraju, izvršavaju, prikazuju i distribuiraju takve informacije i sadržaje i da iz takvih sadžaja koriste bilo koji deo u bilo koje svrhe, kao i pravo i dozvolu da koriste gore navedene sadržaje. Svi zaštitni znakovi (trademarks), logotipi, oznake usluga, firme ili imena proizvoda koji se pominju na ovom web sajtu su vlasništvo kojim raspolažu njihovi vlasnici.