hoeveel error-levels?

Overzicht Reageren

Sponsored by: Vacatures door Monsterboard

Junior Software Developer (HBO / WO)

Functie omschrijving Wij zijn op zoek naar een Junior Software Developer! Sta jij aan het begin van je carrière en heb je net je HBO of WO-diploma in de richting van ICT of Techniek mogen ontvangen? En heb jij grote affiniteit met software development? Dan hebben wij bij Jelling IT Professionals de perfecte opdrachtgever in de omgeving van Utrecht, die jou tot een volwaardig Fullstack Software Developer gaat opleiden. Binnen deze grote organisatie krijg je ruime en professionele trainingen die jouw in korte tijd vakbekwaam maken. Niet alleen het aan technisch aspect, maar ook zeker jouw persoonlijke ontwikkeling wordt veel

Bekijk vacature »

Mendix Consultant / Developer

Dit ga je doen Het in kaart brengen en analyseren van de functionele wensen van de klant rondom Mendix applicaties; Het fungeren als sparringpartner voor de (interne) klanten; Het opstellen van requirements en het vertalen hiervan naar technische mogelijkheden; Het opstellen van user stories; Het bouwen van de Mendix applicaties in samenwerking met jouw team of zelfstandig; Het testen van op te leveren software en het zorg dragen voor de implementatie; Trainen van gebruikers in het gebruik van de applicatie; Werken in een Agile omgeving. Hier ga je werken De organisatie begeeft zich in de retail branche en focust zich

Bekijk vacature »

PHP developer - Digital Agency

Functie Het team telt momenteel 20 collega’s, bestaande uit developers (front- en backend) en het operations team, waaronder ook het management en twee scrum masters vallen. Ze zijn op zoek naar een PHP developer die in staat is zelfstandig te werken. Je komt te werken in één van de drie scrumteams en gaat aan de slag met een project voor de klant. Het fijne hieraan is dat je wel afwisseling hebt qua werk, maar tegelijkertijd doorlopend werkt voor bestaande klanten. Hierdoor krijg je ook de kans om echt de diepte in te gaan en innovatieve technische oplossingen neer te zetten.

Bekijk vacature »

Software Ontwikkelaar .NET te Zaandam

Bedrijfsomschrijving Je komt hier terecht bij een door-en-door softwarebedrijf, waarbinnen meerdere SaaS pakketten worden ontwikkelt voor diverse sectoren. Hierbij kun je denken aan bijvoorbeeld de logistieke en medische branche. Deze organisatie kenmerkt zich door de hoge mate van complexiteit in de applicaties, wat betekent dat jij je hier niet zal gaan vervelen. Integendeel: Jij gaat hier elke dag ontzettend veel leren en je in razend tempo ontwikkelen als C# .Net Developer met focus op back-end. Het team bestaat uit ongeveer 20 personen personen, waarvan het grootste deel zich richt op software development. De sfeer is informeel en professioneel. De producten

Bekijk vacature »

Front-End Developer

As a Front-End Developer at Coolblue you improve the user-friendliness of our webshop for millions of customers. How do I become a Front-End Developer at Coolblue? As a Front-End Developer you work on the user-friendliness of our webshop for millions of customers. You enjoy working with the UX Designer to pick up stories. You get energy from coming up with creative solutions and are happy to present these within the team. You also take pride in your work and welcome any feedback. Would you like to become a Front-End Developer at Coolblue? Read below if the job suits you. You

Bekijk vacature »

Medior/senior Front-end developer

Functie Je maakt deel uit van een DevOps Scrum team en werkt samen met back-end developers, test-engineers, interaction designers en een projectmanager. Er zijn verschillende groepen Scrum teams. Een roadmap team is jouw ‘’thuisbasis’’, daar wordt gewerkt aan doorontwikkeling van bestaande omgevingen voor een aantal klanten. Hiernaast zijn er projectteams waar nieuwe omgevingen worden gebouwd, of grote complexe wijzigingen worden doorgevoerd op bestaande omgevingen. Je kunt (afhankelijk van jouw wensen en doelen) dus afwisselend werken in beide teams. Hiernaast participeer je in het Chapter Front-end development waar gezamenlijk kennis en ervaring wordt gedeeld. Als Front-end developer is het jouw doel

Bekijk vacature »

.NET Developer C#

Dit ga je doen Als developer nieuwe gave features implementeren; Werken met technieken als C# .NET en (REST) API's webservices; Ontwikkelen van koppelingen middels API's; Maken van technische keuzes en beslissingen over de architectuur; Junior collega's coachen; Initiatief nemen voor nieuwe technische mogelijkheden; Je bent een belangrijke schakel - en vindt het leuk - om te schakelen met de business. Hier ga je werken Als C# .NET Developer wordt je verantwoordelijk voor het ontwikkelen van applicaties voor belangrijkste product van deze organisatie. Dit product is een applicatie voor alles omtrent hypotheken. De programmeertaal die je hierbij beheerst is C#. Er

Bekijk vacature »

Microsoft Acess Developer

Functieomschrijving Wat ga je doen? Heb jij ongeveer 3 jaar ervaring als Software Developer, en komen de volgende kennisgebieden jou niet vreemd voor: MS Acces, C# & SQL? Vind jij het daarnaast leuk om maatwerk software te ontwikkelen voor klanten in een bijzondere branche? Lees dan snel verder! Als developer ben jij samen met een gemotiveerd team van 10 collega’s verantwoordelijk voor het creëren van aangemeten software voor klanten. Je bent klantvriendelijk en oplossingsgericht ingesteld, omdat het essentieel is om de klanten zo goed mogelijk te helpen met hun uitdagingen. Het is mogelijk om vanuit huis je werkzaamheden uit te

Bekijk vacature »

Fullstack Developer TOTO

Do you want to work with the latest technologies on the development of new systems and applications? Get moving and strengthen Nederlandse Loterij as a Fullstack Developer TOTO. Thanks to your efforts, complex business critical applications are always running smoothly. In this way, you directly contribute to a happy, healthy and sporty Netherlands. As a Fullstack Developer you score by: Taking ownership of the development cycle of an application in a large scale, high availability, geo redundant landscape Coaching your peer developers and safeguarding code quality Integrating the application with other components of the system using the available API’s Managing

Bekijk vacature »

Junior Software Developer

Functie omschrijving Wij zijn op zoek naar een Junior Software Developer .NET, C# voor een gaaf bedrijf in de omgeving van Utrecht! Sta jij aan het begin van je carrière en heb je net je HBO of WO-diploma in de richting van ICT of Techniek mogen ontvangen? En heb jij grote affiniteit met software development? Lees dan snel verder! Voor een opdrachtgever in de omgeving van Utrecht, zijn wij op zoek naar een Junior Software Developer. Werk jij graag aan verschillende projecten en ga je graag klanten op bezoek? Dan is dit de ideale functie voor jou! Binnen deze functie

Bekijk vacature »

IoT Software Developer PHP

Functie omschrijving Voor een klein softwarebedrijf in Breda, zijn wij op zoek naar een IoT software developer met kennis van PHP. In deze rol wordt je verantwoordelijk voor het vernieuwen van het multimedia platform van een super tof bedrijf in Breda. Je gebruikt PHP als programmeerlaag, en bent in staat om de helicopterview te pakken / projectmatig te werken. Jouw werkzaamheden zien er als volgt uit: Je gaat aan de slag met de ontwikkeling en vernieuwing van het "intern" ontwikkelde multimedia platform. Je neemt de lead in het moderniseren van het platform door het deels opnieuw op te zetten of

Bekijk vacature »

Lead C++ Developer

De rol van Lead C++ Developer Als Lead C++ developer bij KUBUS word je verantwoordelijk voor het implementatie design van requirements en de software architectuur van de desktop applicaties van BIMcollab, ons platform voor 3D model-validatie en issue-management bedoeld om de kwaliteit van 3D design-modellen voor gebouwen te verbeteren. Betere 3D modellen leiden tot betere gebouwen, dus zo draag je bij aan verduurzaming van de gebouwde omgeving met slimmer gebruik van materialen, minder verspilling en energie-efficiënte gebouwen. Een goede gebruikerservaring staat bij ons hoog in het vaandel; we gaan in onze ontwikkeling voor innovatie en kwaliteit. In je rol als

Bekijk vacature »

PHP Developer

Dit ga je doen Ontwikkelen, implementeren en testen van PHP-oplossingen en Apps voor klanten en bedrijfsprocessen; Opstellen van requirements en uitwerken van de oplossingen; Testen van software en borgen van een soepele overdracht, inclusief documentatie; Proactief adviseren vanuit eigen expertisegebied over ontwikkelingen en verbeterpunten in technische toepassingen en processen binnen de organisatie. Hier ga je werken De organisatie is een ambitieuze en vooruitstrevende speler in de markt in de regio Rotterdam. Ze zijn de snelst groeiende in hun branche. Met een excellent aanbod en service willen zij de beste keuze zijn voor hun bestaande en nieuwe klanten. Dit alles doen

Bekijk vacature »

Productontwikkelaar Food

Wat ga je doen Als Productontwikkelaar Food ga je nieuwe producten ontwikkelen en bestaande producten verbeteren. Je bent hierbij betrokken bij het gehele proces: van productconcept naar proefreceptuur, het realiseren va het product (op kleine schaal) en het testen van producten in een productieomgeving. Verder: Bewaak je de status van verschillende fases van productontwikkeling en lever je tijdig de benodigde data aan Ben je bezig met de optimalisatie van oude en nieuwe recepturen Begeleid of organiseer je proefsessies (sensorisch onderzoek) in het team en/of bij klanten Onderhoud je contacten met de klanten, leveranciers van grondstoffen e.a. externe partijen Houd je

Bekijk vacature »

Network Engineer (f/m/d) in Heidelberg

Network Engineer (f/m/d) The IT Services team operates and supports the IT infrastructure and services at EMBL headquarters in Heidelberg and at the laboratory’s sites in Barcelona and Rome. As part of IT Services, the Network team is responsible for managing and developing the network infrastructure in our data centres, on campus, and to our external network providers. As a leading scientific institution with highly data-intensive research, extensive data flows at and between the laboratory’s six sites and to the Internet, EMBL is connected to national and international scientific networks using state-of-the-art technologies from vendors including Cisco, Extreme Networks and

Bekijk vacature »

Pagina: 1 2 3 volgende »

Ozzie PHP

Ozzie PHP

25/11/2013 11:41:35
Quote Anchor link
Ola,

Als er in mijn applicatie iets fout gaat, dan wil ik daar een error-level aan kunnen koppelen.

Zelf dacht ik om gebruik te gaan maken van 3 gradaties:

1) notice: een kleine fout, bijv. een user vult een getal in in plaats van een string
2) warning: een serieuze fout, bijv. een file kan niet worden opgeslagen
3) error: er gaat iets goed mis, bijv. er kan geen database-verbinding tot stand komen

Een notice zou ik dan alleen loggen in een log-bestand. Een warning zou ik zowel loggen als mailen, en bij een error zou ik loggen en mailen en de rest van de applicatie stoppen.

Zijn deze 3 gradaties toereikend volgens jullie? Of zijn er nog tussenstappen te bedenken, en zo ja welke?
Gewijzigd op 25/11/2013 11:49:42 door Ozzie PHP
 
PHP hulp

PHP hulp

23/11/2024 23:52:17
 
Dos Moonen

Dos Moonen

25/11/2013 11:54:31
Quote Anchor link
https://github.com/php-fig/fig-standards/blob/master/accepted/PSR-3-logger-interface.md

Zorg dat alle 8 levels beschikbaar zijn. Hoeveel je er daadwerkelijk gebruikt is een ander verhaal. Das is namelijk jouw keuze.
 
Ozzie PHP

Ozzie PHP

25/11/2013 11:57:06
Quote Anchor link
Hey Dos, deze link zag ik laatst ook voorbij komen. Maar ik vind 8 levels nogal overdreven als je het mij vraagt. Dat is toch veel teveel?
 
Kris Peeters

Kris Peeters

25/11/2013 11:58:45
Quote Anchor link
Er zijn nog onderscheidingen die je kan maken.

- 1) Merk ten eerste op: als er 1 parse error in je .php bestand staat, wordt het hele bestand niet uitgevoerd. Dus dat kan je moeilijk echt opvangen.

- 2) Dan zijn er fouten die een IDE kan vinden. bv. je roept een functie op; die functie is nergens te vinden. Hiervoor moet je php niet uitvoeren om de fout te vinden.

- 3) Runtime errors:
* Stel: je krijgt op basis van een ajax-request een functienaam mee. Bij het uitvoeren van het Ajax-verzoek moet je die functie dan uitvoeren.
Indien je een foute naam krijgt, kan je die functie niet uitvoeren (wegens onbestaande).
Het punt is: de fout ontstaat pas nadat het script is beginnen runnen

* bv. fetchen van een $res die afkomstig is van een mysql_query die false teruggeeft ... Een parser of een IDE kan onmogelijk op voorhand weten dat die $res false zal zijn. Dat weet je slechts in runtime

Als je er in slaagt de twee laatste uit mekaar te halen, zeker doen.

-----

Het punt is vooral: Error 2) zou je eigenlijk nooit mogen voor hebben; tenzij wanneer je aan het schrijven bent.

Runtime errors zijn errors die je in de loop van het gebruik kan merken. Als de website niet grondig getest is, kan je, misschien maanden later, pas voor het eerst die fout zien.
Gewijzigd op 25/11/2013 12:07:46 door Kris Peeters
 
Ozzie PHP

Ozzie PHP

25/11/2013 12:15:42
Quote Anchor link
Kris, dankjewel voor je reactie. Het gaat mij juist om exceptions die je zelf kunt opvangen. Stel dat ik een bestand wil opslaan. Dan doe ik een try en catch. Op het moment dat het bestand niet kan worden opgeslagen, dan wil ik dat er actie wordt ondernomen. De gradatie die hier volgens mij bij hoort is een WARNING (zie mijn eerste bericht). Ik zou dan loggen en (naar mezelf) mailen dat een bestand niet kan worden opgeslagen.

Behalve een WARNING zou ik dan denken aan een NOTICE en een ERROR (zie voor de omschrijving weer mijn eerste bericht). Mijn vraag is of je nog meer levels nodig hebt, of dat dit de lading dekt.
 
Kris Peeters

Kris Peeters

25/11/2013 13:05:06
Quote Anchor link
Ik zou de redenering van php volgen.

Een error stopt het script.
Een warning stopt het script niet. (maar waarschijnlijk zal de gebruiker content ontbreken door de warning)
Een notice betekent zo goed als niets in mijn ogen. Het verandert meestal niets aan de logica.

---

Sowieso, als je voorzichtig bent, krijg je geen errors.
Dat vergt wel extra if's, soms diep genest.

Maar jij suggereert om zelf exceptions op te roepen.
Dat is meer de Java aanpak. Mensen met een C verleden, zullen dat waarschijnlijk wat minder doen.
Mij geen probleem hoor.
 
Ozzie PHP

Ozzie PHP

25/11/2013 13:11:40
Quote Anchor link
@Kris: dat zijn dus ook de 3 levels die ik in gedachten had.

Euh, het is toch goed om exceptions te gebruiken?
 
Ward van der Put
Moderator

Ward van der Put

25/11/2013 13:51:23
Quote Anchor link
Kris Peeters op 25/11/2013 13:05:06:
Ik zou de redenering van php volgen.

Dat is een lastige redenering, want als je die lijn doortrekt, zou je alles afhankelijk moeten maken van de huidige instelling van error_reporting() en bij exceptions moeten terugvallen op de Standard PHP Library (SPL).

Bij een OOP framework kun je, denk ik, beter het advies van Dos volgen en de LoggerInterface implementeren. Die logt ook meer dan alleen fouten, waaronder "interesting events" zoals een gebruiker die inlogt, en heeft een apart level voor debugging. Heb je dat ook meteen meegenomen.
 
Ozzie PHP

Ozzie PHP

25/11/2013 13:56:54
Quote Anchor link
>> waaronder "interesting events" zoals een gebruiker die inlogt

Dit kan inderdaad interessant zijn, maar heeft verder niets met error handling te maken. Ik wil graag weten hoeveel gradaties er zijn waarin je zelf fouten kunt afhandelen. Volgens mij zijn dat er maar 3:

notice - er gaat iets kleins mis, bijv. een user die verkeerde input invoert
warning - er gaat serieus iets mis wat aandacht nodig heeft, bijv. een bestand dat niet kan worden opgeslagen
error - foute boel, er gaat iets dusdanig mis dat de applicatie gestopt moet worden, bijv. een database die geen connectie kan maken

Ik zou denken dat dit alles is, maar wellicht zie ik iets over het hoofd?

>> en heeft een apart level voor debugging

Wat kun je hier eigenlijk mee. Waar heb je dit voor nodig?
 
Ward van der Put
Moderator

Ward van der Put

25/11/2013 14:18:12
Quote Anchor link
Als je exceptions afvangt, zijn drie niveaus niet toereikend. Je hebt dan niet slechts "een error", maar bijvoorbeeld ook een catchable runtime error. Neem een cURL-verbinding die upstream ergens data vandaan haalt: die kan een error (server onbereikbaar) keren in een warning wanneer je terug kunt vallen op een lokale cache. In een log wil je daarvoor twee items op een ander niveau terugvinden: het falen van de cURL-verbinding en aansluitend het gemopper van de klasse die de verbinding gebruikte.

Debuggen kun je zo simpel of uitgebreid maken als je zelf wilt. Bij exceptions is vooral Exception::getTrace() belangrijk: hieruit kun je aflezen welke route exceptions hebben afgelegd door je applicatie. De LoggerInterface leent zich ook voor het loggen van dit soort debugmeldingen. Vandaar dat ik het advies van Dos zou volgen: implementeer de LoggerInterface, want dan ben je meteen klaar en hoef je niet later het wiel opnieuw uit te vinden.
 
Ozzie PHP

Ozzie PHP

25/11/2013 14:27:35
Quote Anchor link
>> Als je exceptions... die de verbinding gebruikte.

Oké, maar op het moment dat je applicatie door kan gaan dan is het dus een WARNING (iets wat aandacht behoeft, maar de applicatie hoeft niet te stoppen).

Wat betreft het debuggen. Ik begrijp niet WANNEER je een debug-actie wilt loggen. Als er iets fout gaat wil je toch altijd debug informatie hebben?
 
Ward van der Put
Moderator

Ward van der Put

25/11/2013 14:40:50
Quote Anchor link
Ozzie PHP op 25/11/2013 14:27:35:
>> Als je exceptions... die de verbinding gebruikte.

Oké, maar op het moment dat je applicatie door kan gaan dan is het dus een WARNING (iets wat aandacht behoeft, maar de applicatie hoeft niet te stoppen).

Niet als je OOP programmeert. De cURL-klasse weet dan niet waarvoor zij wordt gebruikt en hoort dat ook niet te weten. Die klasse kan dus geen onderscheid maken tussen een warning en een notice. Pas de andere klasse maakt daarvan een notice als deze het probleem in een catch omzeilt.

Ozzie PHP op 25/11/2013 14:27:35:
Wat betreft het debuggen. Ik begrijp niet WANNEER je een debug-actie wilt loggen. Als er iets fout gaat wil je toch altijd debug informatie hebben?

Meestal wil je dat natuurlijk op je scherm zien. Maar er zijn situaties waarin loggen beter is. Straks laat je bijvoorbeeld testgebruikers los op een bèta. Je gaat dan niet zitten wachten op hun bugreports, maar logt de bugs.

Als je met twee schermen werkt, kun je sneller debuggen door de log live naast de applicatie te tonen. Dat is makkelijker dan in het onderwaterscherm van een HTML-pagina naar foutmeldingen gaan zitten zoeken.
 
Wouter J

Wouter J

25/11/2013 14:42:08
Quote Anchor link
Je moet onderscheid maken tussen error levels en log levels. Een error is slechts een fatal, error, notice of warning. Je wilt echter veel meer gegevens loggen dan alleen de errors. In een dev. omgeving wil ik bijv. graag precies weten welke acties er zijn ondergaan, welke router heeft gematched, etc.

En wat denk je van user handelingen? Ik zou graag willen loggen welke acties een moderator doet, zodat die bij gehouden kunnen worden.

Voor het loggen heb je dus nog veel meer informatie om te loggen, daarom heb je ook meer levels nodig. En dan zal ik altijd de psr standarden volgen.
 
Ozzie PHP

Ozzie PHP

25/11/2013 15:20:04
Quote Anchor link
>> Niet als je OOP programmeert. De cURL-klasse weet dan niet waarvoor zij wordt gebruikt en hoort dat ook niet te weten. Die klasse kan dus geen onderscheid maken tussen een warning en een notice. Pas de andere klasse maakt daarvan een notice als deze het probleem in een catch omzeilt.

Dit is ook wat ik bedoel. Ik wil een exception opvangen en afhankelijk van de aard (gradatie) van de exception wil ik die exceptnio bijv. loggen en mailen. Dit wil ik laten doen door een handler. Door de juiste error mee te geven, moet die handler dan loggen, mailen of in het uiterste geval de applicatie stoppen.

Wat betreft debuggen... ik snap dat je niet wilt dat gebruikers debug-informatie zien. Ik snap niet waarom debug een log-level is. Het is toch helemaal geen level? Ieder "level" kun je zelf voorzien van debug-informatie dus ik snap het nut niet zo goed.

@Wouter:

Ik snap wat je bedoelt met het verschil tussen error en log levels. Goed dat je dat onderscheid maakt. Mij gaat het het dus om de error levels. Jij zegt:

"Een error is slechts een fatal, error, notice of warning"

Volgens jou zijn het er dan 4? Wat is precies het verschil tussen fatal en error?
 
Ward van der Put
Moderator

Ward van der Put

25/11/2013 16:00:58
Quote Anchor link
Ozzie PHP op 25/11/2013 15:20:04:
Dit is ook wat ik bedoel. Ik wil een exception opvangen en afhankelijk van de aard (gradatie) van de exception wil ik die exceptnio bijv. loggen en mailen. Dit wil ik laten doen door een handler. Door de juiste error mee te geven, moet die handler dan loggen, mailen of in het uiterste geval de applicatie stoppen.

De logger logt. Laat je de logger meer doen, dan leg je te veel verantwoordelijkheid bij de logger. De logger moet bij mijn voorbeeld weten dat het ene gebruik van de cURL-klasse mag eindigen in een notice en het andere gebruik in een warning. Daarvoor moet de logger niet alleen de cURL-klasse kennen, maar ook inzicht hebben in hoe andere klassen die klasse gebruiken. Dat wil je niet. Je logt de warning van A en als die ontaardt in een notice bij B, dan log je die opnieuw.

A weet helemaal niet dat B gaat loggen. A is zich zelfs niet bewust van het bestaan van B. En je wilt ook geen A bouwen die per se door B moet worden gebruikt omdat er anders niets wordt gelogd.

Een klasse hoeft daarom ook niet te weten wanneer de logger een mail bij een kritieke fout de deur uitdoet naar de juiste dienstdoende persoon. Dat maakt klassen dan té "logger aware". Alleen een level is ruim voldoende; daarna is het aan de logger om te bepalen hoe er wordt gelogd.
 
Ozzie PHP

Ozzie PHP

25/11/2013 16:19:46
Quote Anchor link
Ward, misschien praat ik soms te snel of onvolledig. Mijn excuses daarvoor. Maar mijn idee is het volgende. Ik wil een exception handler maken. Op het moment dat ik een exception/error afvang waar iets mee moet gebeuren, dan wil ik die error doorsturen naar de exception handler. Hier wil ik dan een error-level aan koppelen. Op basis van de error-level beslist de exception handler wat er moet gebeuren (loggen, mailen, applicatie killen). Je krijgt dus zeg maar zoiets:

Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
4
5
6
7
<?php
try {
  $this->cacher->cache($data, 'foo');
catch (CacherException $e) {
  $this->exception_handler('Could not cache data', $e, WARNING);
}

?>

of

Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
4
5
6
7
<?php
try {
  $config = $this->database->get('website_config');
catch (DatabaseConnectionException $e) {
  $this->exception_handler('No database connection', $e, ERROR);
}

?>

Een class method vangt dus ergens een exception op, en afhankelijk van de aard van die exception wordt in sommige gevallen de exception handler ingeschakeld. Aan die exception handler wil ik dan een level kunnen meegeven. Die handler weet aan de hand van het level wat er vervolgens moet gebeuren.
Gewijzigd op 25/11/2013 16:21:21 door Ozzie PHP
 
Dos Moonen

Dos Moonen

25/11/2013 16:31:30
Quote Anchor link
Quote:
Zorg dat alle 8 levels beschikbaar zijn. Hoeveel je er daadwerkelijk gebruikt is een ander verhaal. Das is namelijk jouw keuze.

Wat heb jij tegen wel 5(!(???)) extra levels toevoegen zodat je de zelfde waarde door kan geven aan een Psr logger?
 
Ozzie PHP

Ozzie PHP

25/11/2013 16:34:07
Quote Anchor link
Op zich heb ik er niks op tegen, mits ze een meerwaarde hebben. Die zie ik nu niet. Maar aangezien ik niet alwetend ben kun jij het misschien uitleggen?
 
Wouter J

Wouter J

25/11/2013 16:35:57
 
Ward van der Put
Moderator

Ward van der Put

25/11/2013 16:43:01
Quote Anchor link
Ozzie PHP op 25/11/2013 16:19:46:
Een class method vangt dus ergens een exception op, en afhankelijk van de aard van die exception wordt in sommige gevallen de exception handler ingeschakeld. Aan die exception handler wil ik dan een level kunnen meegeven. Die handler weet aan de hand van het level wat er vervolgens moet gebeuren.

In A treedt een onverwachte fout op. Gelukkig niet zo erg: je had het ding namelijk in een if verpakt die bij false een exception gooit. Aangekomen bij B blijkt de fout toch minder onschuldig te zijn: het PHP-script crasht hard in de try, nog voordat het in de catch belandt. Hoe wil je dan nog bij een logger uitkomen?

Als je het loggen almaar vooruit schuift, kom je er soms niet meer aan toe. Of je vergeet het, want van uitstel komt afstel en "dat doe ik morgen wel". Ondertussen blijven bugs onopgemerkt.
 
Ozzie PHP

Ozzie PHP

25/11/2013 16:51:34
Quote Anchor link
@Wouter:

Kun je nog het verschil uitleggen tussen FATEL en ERROR?

Uit jouw link (thanks):

Emergency: system is unusable
Alert: action must be taken immediately
Critical: critical conditions
Error: error conditions
Warning: warning conditions
Notice: normal but significant condition
Informational: informational messages
Debug: debug-level messages

Ik zie het hier staan... maar ik weet niet hoe ik dan onderscheid moet maken. Wat is bijvoorbeeld het verschil tussen een error en critical? En tussen critical en alert? Dat komt toch allemaal op hetzelfde neer?

@Ward:

Ik voel dat je me iets probeert duidelijk te maken, maar ik zie het licht nog niet helemaal. Kun je eens schematisch een praktijkvoorbeeldje geven van wat je bedoelt?
 

Pagina: 1 2 3 volgende »



Overzicht Reageren

 
 

Om de gebruiksvriendelijkheid van onze website en diensten te optimaliseren maken wij gebruik van cookies. Deze cookies gebruiken wij voor functionaliteiten, analytische gegevens en marketing doeleinden. U vindt meer informatie in onze privacy statement.