PiRANiA | zaterdag 5 december 2009 @ 15:50 | |||||||
cd niet bijgeleverd Als je vragen hebt over PHP/MySQL, dan zit je hier goed met een vaste kliek guru's en een groot aantal regelmatige bezoekers. Beperk je vragen niet tot "hij doet het niet" of "hij geeft een fout" - onze glazen bol is kapot en we willen graag van je weten wát er niet lukt en wélke foutmelding je precies krijgt Vorige delen: 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74,75, 76, 77 Zie ook: Tutorials: Deze OP en instructies voor nieuw topic: http://wiki.fok.nl/index.php/OP/PHP | ||||||||
GlowMouse | zaterdag 5 december 2009 @ 15:50 | |||||||
tvp en voor css vragen moet je hier niet zijn | ||||||||
NoShitSherlock | zaterdag 5 december 2009 @ 15:51 | |||||||
Weet hier iemand hoe je PHP files opmaakt met css?? Ik heb namelijk een css file die nu niet werkt met de php file. Althans niet met de tabel die in een PHP code staat. De pagina die buiten de PHp code staat wordt wel correct opgemaakt door de CSS file. Weet iemand hoe je dit oplost??? | ||||||||
SpaceLlama | zaterdag 5 december 2009 @ 15:53 | |||||||
quote:... Ja want dan is een HTML tabel opeens anders! toch? | ||||||||
PiRANiA | zaterdag 5 december 2009 @ 16:04 | |||||||
NoShitSherlock maak je excuses eens! Geen nieuw topic openen. Schavuit | ||||||||
GlowMouse | zaterdag 5 december 2009 @ 16:06 | |||||||
quote:zal ik dan maar normaal antwoorden quote:controleer de html output, want dit ligt niet aan php. | ||||||||
NoShitSherlock | zaterdag 5 december 2009 @ 16:12 | |||||||
quote:Maar hoe kan ik dan zo'n klote tabelletje opmaken? Ik heb dus een php bestandje die de gegevens uit een database haalt en in een html tabel zet die als volgt opgebouwd is ( dit is maar een stukje van de totale code):
En nu dacht ik de tabel als volgt te kunnen opmaken ( zie onderstreepte tekst):
Maar als ik dan de php file upload dan laad die helemaal niks meer. Hoe moet ik zo'n tabel opmaken dan? | ||||||||
GlowMouse | zaterdag 5 december 2009 @ 16:13 | |||||||
lees http://php.net/manual/en/language.types.string.php | ||||||||
hamkaastosti | zaterdag 5 december 2009 @ 16:19 | |||||||
lollertvp @noshitsherlock hint: je kunt zovaak je wil <?php en ?> php gebruiken om te wisselen tussen php en html | ||||||||
GlowMouse | zaterdag 5 december 2009 @ 16:21 | |||||||
quote:dat wil je niet | ||||||||
hamkaastosti | zaterdag 5 december 2009 @ 16:23 | |||||||
quote:och.. ik gebruik het in m'n views regelmatig hoor. je hele html echo'en en alles aan elkaar concatenaten vind ik ook niet echt een ideale situatie | ||||||||
NoShitSherlock | zaterdag 5 december 2009 @ 16:25 | |||||||
quote:Kan je dat misschien zo toepassen op die tabel die ik hierboven beschreef zodat css de tabel kan opmaken?? Maar ik kan dan toch niet zomaar die sessie stoppen? Want dan gaat de tabel natuurlijk niet gevuld worden lijkt me. | ||||||||
hamkaastosti | zaterdag 5 december 2009 @ 16:34 | |||||||
ik? nee ik weet niets van php | ||||||||
GlowMouse | zaterdag 5 december 2009 @ 16:43 | |||||||
quote:ja tuurlijk, maar middenin een regel 3x wisselen is niet handig. en NSS moet gewoon mijn link lezen | ||||||||
Mirel | zaterdag 5 december 2009 @ 16:49 | |||||||
tvphp | ||||||||
Light | zaterdag 5 december 2009 @ 21:47 | |||||||
Oh, nieuw topic. | ||||||||
ssmm987 | zondag 6 december 2009 @ 09:35 | |||||||
quote:Doordat je " gebruikt in zowel je html, en je php, denkt de php dat tabel1 php code is, wat een fatal error geeft, omdat het niet goed gebruikt is. Er zijn drie manieren om dit op te lossen: 1.Escape de " dingen in de html door er een \ voor te zetten Vb: "<td class=\"tabel1\">" Deze manier valt niet aan te raden, omdat wanneer het niet nodig is, je echo altijd met een enkele ' opent en sluit. 2.Gebruik ' dingen Vb: echo '<td class="tabel1">' Is beter dan de eerste mogelijkheid, maar nog steeds niet helemaal perfeect 3.Haal de html uit de php
Het netst en het meest overzichtelijk, en het makkelijkst te maken | ||||||||
Light | zondag 6 december 2009 @ 09:43 | |||||||
Bedoel je niet toevallig <?= in plaats van <= ? Of short open tags ( <? ) werken, is afhankelijk van serverinstellingen. 't Is dus beter om daar niet op te vertrouwen en gewoon <?php te schrijven. | ||||||||
hamkaastosti | zondag 6 december 2009 @ 09:56 | |||||||
zonder echo zal d'r nog steeds weinig in je browser verschijnen arhgh... haalt dat verrekte forum weer een aantal tags weg
| ||||||||
Chandler | zondag 6 december 2009 @ 09:58 | |||||||
tijd voor een post | ||||||||
Darkomen | zondag 6 december 2009 @ 11:23 | |||||||
quote:zo-eentje | ||||||||
NoShitSherlock | zondag 6 december 2009 @ 15:57 | |||||||
quote:Thnx man! Ik heb de eerste methode gebruikt en dit werk perfect. | ||||||||
xaban06 | zondag 6 december 2009 @ 16:41 | |||||||
Met mijn code krijg ik allemaal losse arrays, ik wil 1 groot array. Ik kom er maar niet op hoe ik dit ga fixen :@
| ||||||||
GlowMouse | zondag 6 december 2009 @ 16:43 | |||||||
$data[] = array ($month, $day, $hour, $avail). | ||||||||
xaban06 | zondag 6 december 2009 @ 16:48 | |||||||
quote:Thanks! Nu eens uitzoeken hoe ik er mee overweg moet | ||||||||
wobbel | zondag 6 december 2009 @ 18:23 | |||||||
Zucht...mijn PHP upload script geeft het bestand wel 644 chmod rechten, maar de verkeerde user. Normaal zijn alle bestanden op mijn server "wobbel psacln" (eigenaar/groep) maar als ik met PHP upload krijg ik "apache apache". Met chown kan ik hier schijnbaar niks mee veranderen, of ik doe het niet goed...maar het zuigt iig want nu kan ik ze niet verwijderen met FTP (alleen met PHP zelf weer)
Alleen WoBBeL werkt ook niet.... (ben van ellende eigen filemanager voor CKeditor aan het maken ) | ||||||||
Etimm | zondag 6 december 2009 @ 18:40 | |||||||
Ik ben bezig om een rss feed editor te maken. Ik ben tot nu toe overal uit gekomen behalve het sorteren. deel uit het xml bestand:
Ik maak gebruik van SimpleXML om feed in een array te plaatsen.
Nu wil ik de items in de array $xml sorteren op pubDate Iemand een idee? | ||||||||
wobbel | zondag 6 december 2009 @ 18:48 | |||||||
quote:http://www.webmasterworld.com/forum88/12595.htm ? | ||||||||
JortK | zondag 6 december 2009 @ 19:19 | |||||||
Hoi | ||||||||
wobbel | zondag 6 december 2009 @ 19:22 | |||||||
quote:Hai | ||||||||
GlowMouse | zondag 6 december 2009 @ 19:26 | |||||||
quote:Apache onder jouw username draaien of de map waarin de bestanden geplaatst worden anders chmodden. Chown lukt iig niet, want zoals de manual al zegt, kan dat alleen als je apache als root draait. | ||||||||
Light | zondag 6 december 2009 @ 19:44 | |||||||
quote:Ik vermoed dat het shared hosting is, dan is het niet zo makkelijk om apache met je eigen user te laten draaien. Andere optie is om de rechten op 666 te zetten (en 777 voor directories). Dan kun je de bestanden wel via ftp verwijderen. | ||||||||
wobbel | zondag 6 december 2009 @ 19:59 | |||||||
quote:Site draait onder Plesk, dus de hoster kan er ook weinig aan veranderen. quote:Dat laatste truukje ga ik eens proberen [edit] Mmmm...chmodje staat netjs op 666 voor een jpg bestand maar helaas... Commando: DELE 1260126668_CIMG1292.JPG Antwoord: 550 1260126668_CIMG1292.JPG: Permission denied | ||||||||
GlowMouse | zondag 6 december 2009 @ 20:10 | |||||||
het geldt alleen voor nieuwe bestanden omdat die de chmod overnemen van de map waarin ze komen | ||||||||
wobbel | zondag 6 december 2009 @ 20:13 | |||||||
quote:
en de geuploadde bestanden kan ik dan alsnog niet verwijderen | ||||||||
GlowMouse | zondag 6 december 2009 @ 20:14 | |||||||
ik geloof er niks van | ||||||||
Light | zondag 6 december 2009 @ 20:21 | |||||||
quote:Wie is de eigenaar van de directory waar de bestanden in staan, en wat zijn de rechten? | ||||||||
wobbel | zondag 6 december 2009 @ 20:26 | |||||||
quote:bestand eigenaar is "apache apache", bestand heeft chmod 666 eigenaar van de map is "wobbel psacln", map heeft chmod 777 | ||||||||
GlowMouse | zondag 6 december 2009 @ 20:46 | |||||||
als de map van jou is, en de file heeft chmod 666, dan kun je hem verwijderen | ||||||||
wobbel | maandag 7 december 2009 @ 00:23 | |||||||
quote:Mja, toch niet...maargoed...het wordt straks toch beheerd met PHP dus wat maakt het uit Ow en voor iedereen die loopt te zeiken dat CKeditor geen File Manager heeft...het is echt in een half dagje te fixen | ||||||||
Etimm | maandag 7 december 2009 @ 10:55 | |||||||
quote:Daar kom ik dus niet uit... Iemand die me kan uitleggen hoe ik de array kan sorteren op pubDate? [ Bericht 1% gewijzigd door Etimm op 07-12-2009 11:47:51 ] | ||||||||
Light | maandag 7 december 2009 @ 12:02 | |||||||
quote:Met usort moet je een heel eind kunnen komen. | ||||||||
Etimm | maandag 7 december 2009 @ 22:48 | |||||||
Ben er helaas nog niet helemaal uitgekomen... maar dat komt vast wel een x goed. Zit nu met nog een andere uitdaging. Hoe kan ik item[1] en alle onderliggende items verwijderen?
<rss> <channel> <item> <titel>titel 1</titel> <link>www.link1.nl</link> </item> <item> <titel>titel 2</titel> <link>www.link2.nl</link> </item> <item> <titel>titel 3</titel> <link>www.link3.nl</link> </item> </channel> </rss> [ Bericht 7% gewijzigd door Etimm op 07-12-2009 23:13:54 ] | ||||||||
ursel | dinsdag 8 december 2009 @ 19:19 | |||||||
even zwaaien | ||||||||
Tuvai.net | dinsdag 8 december 2009 @ 19:56 | |||||||
Ik ben nog steeds een beetje met MySQL en InnoDB in het bijzonder aan het stoeien. Ik stuit nu echter op een vreemd verschijnsel. Ik heb de volgende, eenvoudige tabel:
Dit is, zoals de structuur al impliceert, een tabel voor een recursieve boom-structuur. Nu wil ik echter dat je per 'niveau' niet twee keer dezelfde NAME kunt invoeren. Ik heb dus een unique constraint gelegd op de kolommen PARENT en NAME. Nu werkt dit prima, ik kan bijvoorbeeld niet twee keer een record toevoegen waar PARENT 1 is, en NAME 'bla' is. Dit werkt echter niet wanneer PARENT NULL is. Met andere woorden, ik kan dus twéé keer een record met PARENT = NULL en NAME = 'bla' invullen, hetgeen dus niet de bedoeling zou moeten zijn. Hoe kan dit? In de andere platformen waar ik op werk (voornamelijk MSSQL en Oracle) werkt dit wél gewoon. EDIT: Ik zie hier nog iemand die hetzelfde probleem heeft op het MySQL forum: http://forums.mysql.com/read.php?22,53591,53591 Een 'nep' waarde als 9999999 of 0 in de PARENT kolom gooien indien deze daadwerkelijk 'NULL' zou moeten zijn, is geen optie. Op de PARENT kolom ligt namelijk een foreign key, en bovendien is zo'n nep waarde slordig en bovenal onlogisch. | ||||||||
GlowMouse | dinsdag 8 december 2009 @ 19:57 | |||||||
Unique werkt niet icm NULL (zie documentatie; http://dev.mysql.com/doc/refman/5.0/en/create-index.html ). Een alternatief is de waarde 0 gebruiken ipv NULL als er geen parent is. | ||||||||
Tuvai.net | dinsdag 8 december 2009 @ 20:01 | |||||||
quote:Ik had nog een ninja edit geplaatst. En da's best wel zuur dan. Niet echt logisch. | ||||||||
Tuvai.net | dinsdag 8 december 2009 @ 21:05 | |||||||
Nou, heel Google en MySQL.com in het bijzonder af zitten struinen en er is inderdaad niet echt een oplossing voor. Dan voor deze keer maar een uitzondering maken en deze databasetechnische controle op applicatie-niveau leggen. | ||||||||
GlowMouse | dinsdag 8 december 2009 @ 21:07 | |||||||
Dat kon ik zo ook wel zeggen dat je er niet anders omheen kunt werken | ||||||||
Tuvai.net | dinsdag 8 december 2009 @ 21:11 | |||||||
quote:Ik was er al bang voor en had zo'n vermoeden, maar ik wou toch even zeker weten. Ik vind het wel echt zuur. Ik heb zo ook bijvoorbeeld in het gros van mijn tabellen een 'delDate' kolom, die is NULL wanneer het betreffend record niet 'ge`delete' is, en bevat de timestamp van de verwijderdatum wanneer deze record wel 'ge`delete' is. Uiteraard is het de bedoeling dat wanneer een tabel een UNIQUE constraint op diverse kolommen heeft, deze de 'delDate' kolom ook meeneemt (anders krijg je immers constraint violations op records die in de applicatie 'verwijderd' zijn). Deze vlieger gaat helaas ook niet op. Nu moet ik daar inderdaad een beetje valsspelen door 0 te gebruiken in plaats van NULL. OF al deze checks op al deze tabellen op applicatieniveau gaan verleggen, maar dat is een onbegonnen en erg slordig karwei. Als er één ding is waar ik een hekel aan heb, dan is het wel een onlogische database. | ||||||||
Kwyjibo | woensdag 9 december 2009 @ 00:05 | |||||||
Hallo allemaal, Al een tijdje ben ik bezig met het zoeken naar een oplossing voor mijn website waar ik mee bezig ben. Bedoeling is dat bezoekers in realtime iets aan kunnen vinken en dat deze status dan bewaard blijft. Op mijn vorige opleiding heb ik wel enige kennis opgedaan met php en mysql maar in deze kwestie kom ik er niet uit. Als je niet begrijpt wat ik bedoel kijk op de site: bierdopje.com Hier kan je realtime aanvinken welke aflevering je hebt gezien. Het grijze icoontje veranderd direct in een groene als je het aanklikt. Maar hoe wordt dit gedaan? En in welke taal? Wie oh wie kan mij helpen? Alvast bedankt! | ||||||||
GlowMouse | woensdag 9 december 2009 @ 00:07 | |||||||
Front-end gaat dit mbv xmlHTTP. Dit kun je vrij makkelijk met een toolkit als jQuery. Je moet wel met JavaScript en PHP kunnen werken. | ||||||||
Kwyjibo | woensdag 9 december 2009 @ 00:18 | |||||||
quote:Dankje voor je reactie! Nu kom ik wat verder. Is het dan ook zo te maken dat het gekoppeld kan worden aan een user? Erg tof dat Fok! users je altijd willen helpen Heb misschien al wat gevonden: http://widowmaker.kiev.ua/checkbox/ eens kijken of ik hier wat mee kan. [ Bericht 12% gewijzigd door Kwyjibo op 09-12-2009 00:23:53 ] | ||||||||
The_Tankgirl | vrijdag 11 december 2009 @ 09:31 | |||||||
hi! Even voor alle dummies zoals ik die een boek zoeken om php te begrijpen: Ik ben nu bezig met het boek: PHP for the web visual quickstart guide (third edition), en dit is echt het eerste boek over php waar ik wel doorheen kom Ik zou wel de Engelse versie nemen, omdat deze het meest recent is, de laatste Nederlandse versie komt uit 2004 ofzo. Echt een aanrader dus! Misschien ook een ideetje om een rijtje met aanbevolen boeken te maken ofzo? | ||||||||
Chandler | vrijdag 11 december 2009 @ 17:35 | |||||||
Ik zit met een punt. Ik laad een database class naar $db en laad daarna een nieuwe class (user) en wil deze als parameter de $db class meegeven
nu krijg ik echter de volgende error :? Fatal error: Using $this when not in object context in D:\****\system\classes\class.user.php on line 23 Wat doe ik nou weer fout? :D | ||||||||
Light | vrijdag 11 december 2009 @ 18:16 | |||||||
Wat staat er op regel 23? Is dat toevallig regel 21 van de code die je hebt gepost? Zo ja, poets dat "static" eens weg bij de loginfunctie. | ||||||||
Tuvai.net | vrijdag 11 december 2009 @ 18:38 | |||||||
quote:$this is alleen van toepassing als je het hebt over geinstantiëerde classes / objecten. De static 'modifier' wil zeggen dat je de functie (eigenlijk is het een method / member als je zo'n functie in een class hebt) kunt aanroepen zonder de class / het object dat de class voorstelt te instantiëren. | ||||||||
Chandler | vrijdag 11 december 2009 @ 20:09 | |||||||
OMG! dat is het inderdaad, dat je daar zo lang overheen kunt kijken Klop idd dat het dan niet werkt met $this, self:: zou dan wel weer werken maar daar heb ik niets mee van doen in deze class.. bedankt! | ||||||||
Tuvai.net | vrijdag 11 december 2009 @ 20:56 | |||||||
Als je toch met classes / objectgeoriënteerd wilt gaan werken, raad ik je aan om de basiskennis zoals de betekenis van 'access control modifiers' (public, protected, private, abstract, etc), inheritance / class deriving en het hele nut van instantiëerbare en niet-instantiëerbare classes / objecten goed onder de knie te krijgen. Het is erg eenvoudig, en als je dat eenmaal onder de knie hebt, pik je erg eenvoudig andere (nieuwe) objectgeoriënteerde talen op. | ||||||||
Chandler | zaterdag 12 december 2009 @ 08:49 | |||||||
Moet zeggen dat ik dat al aardig wat kaas gegeten heb van classes, alleen heb ik hier gewoon uren overheen gekeken | ||||||||
Trollface. | zaterdag 12 december 2009 @ 17:16 | |||||||
TVPHP | ||||||||
ursel | zondag 13 december 2009 @ 17:32 | |||||||
Weet iemand hoe ik er ook alweer voor kan zorgen dat ik de service php, pear en phpunit kan benaderen vanuit een andere folder dan de std folders? | ||||||||
Chandler | maandag 14 december 2009 @ 10:15 | |||||||
Ik heb ook weer een vraag, stel je werkt met formulieren en wil fouten opslaan voor display, hoe doen jullie dit? hebben jullie hiervoor een gereserveerde sessie/variabel/array/class? | ||||||||
hamkaastosti | maandag 14 december 2009 @ 10:35 | |||||||
ik heb een validator class waar ik alle input mee check. $validator->getErrors(); geeft een array van alle velden terug waar wat mis mee is en wat er mis mee is. | ||||||||
Chandler | maandag 14 december 2009 @ 15:37 | |||||||
Ah, zo'n opzet heb ik idd ook al hoef ik niet de functie te laden maar gewoon een array over te nemen. $_SESSION['errors'] = array_merge($_SESSION['errors'], $validator->errors); Dus lijkt me goed of is een functie beter? | ||||||||
GlowMouse | maandag 14 december 2009 @ 15:42 | |||||||
quote:eerst chdir? | ||||||||
ursel | maandag 14 december 2009 @ 15:52 | |||||||
quote:ahh.. w8 ff ik mis wat essentiele info in mijn post.. Bedoeling is om het vanaf de command line te runnen. Heb momenteel XAMPP lokaal staan en wil voor wat batch files vanuit een batch folder een php command kunnen runnen, maar moet nu of vanuit de php folder doen en dan volledige path van de te runnen batch file. of vice versa. Zelfde geld eigenlijk ook voor de optie van phpunit. pear is in deze niet geheel belangrijk. | ||||||||
GlowMouse | maandag 14 december 2009 @ 15:54 | |||||||
vice versa | ||||||||
xaban06 | maandag 14 december 2009 @ 19:03 | |||||||
Ik heb een login script geschreven voor mijn project, daarbij heb ik ook de functie 'onthoud mij'. Er wordt een $unique gemaakt, de waarde daarvan is de md5 van {useragent, ip adres, user id}. De md5 hash + de gegevens worden opgeslagen in een database. $unique wordt als een cookie opgeslagen bij de client. Wanneer de gebruiker terug komt, checkt mijn script de IP adres + md hash in de database, indien deze overkomen wordt de gebruiker ingelogt. Tot hier is alles in orde, maar wat als zijn cookie wordt gestolen door iemand anders thuis? Dus als ze achter een NAT zitten. Dan kan diegene ook inloggen. Hoe kan ik dit oplossen? | ||||||||
Tuvai.net | maandag 14 december 2009 @ 19:25 | |||||||
Een cookie wordt alleen 'gestolen' wanneer iemand op dezelfde machine, onder dezelfde gebruikersaccount in logt. Al zijn er natuurlijk wel 'omweggetjes' om een ander account te 'impersonaten'. Overweeg anders eens een session, voor dat beetje extra beveiliging. | ||||||||
Chandler | maandag 14 december 2009 @ 20:40 | |||||||
quote:Op zich niet, tenzij je net zoals bij fok het aanpassen van accounts etc laat bevestigen dmv een wachtwoord (zelfde als inloggen) en natuurlijk kun je middels een tekst de gebruiker er van op de hoogte brengen dat het risico is dat men op de pc (indien deze gebruikt wordt door meerdere mensen) het niet aan te bevelen is om ingelogd te blijven! ): | ||||||||
xaban06 | maandag 14 december 2009 @ 20:52 | |||||||
quote:Ah dus ik doe niks fout Thanks. Op werk namelijk een discussie gehad dat ik fout bezig ben en dat het veel veiliger en makkelijker kan. | ||||||||
Sitethief | dinsdag 15 december 2009 @ 08:55 | |||||||
De $data die ik mee geef aan de function komt uit een $_POST . De class geeft mij alleen de laatste value uit de array terug en negeert de rest. Weet iemand hoe dat komt? | ||||||||
ursel | dinsdag 15 december 2009 @ 09:35 | |||||||
quote:Omdat je binnen je foreach returned | ||||||||
Sitethief | dinsdag 15 december 2009 @ 09:51 | |||||||
quote:Hmm, het maakt niet uit waar ik hem return in de function, ik krijg alleen de laatste waarde uit de array terug. Ik snap wel ongeveer wat er mis gaat, maar niet hoe ik het kan fixen.... Edit: na de foreach() zit er überhaupt maar een value in de array. In de foreach() zelf zitten ze er nog wel allemaal in. [ Bericht 6% gewijzigd door Sitethief op 15-12-2009 10:26:27 ] | ||||||||
Sitethief | dinsdag 15 december 2009 @ 10:52 | |||||||
Ik weet nu wat er mis gaat, omdat ik een array creëer in de loop zal hij altijd de laatste waarde hebben. Ik moet de array dus buiten de loop aanmaken. | ||||||||
Sitethief | dinsdag 15 december 2009 @ 11:21 | |||||||
Zo werkt ie wel. | ||||||||
Sitethief | donderdag 17 december 2009 @ 11:23 | |||||||
En zo is ie een stuk netter. | ||||||||
hamkaastosti | donderdag 17 december 2009 @ 12:38 | |||||||
email checken:
| ||||||||
Chandler | donderdag 17 december 2009 @ 14:55 | |||||||
@hamkaastosti; wil alleen even melden dat die filter ook niet 100% werkt, zelfs niet 50% http://www.google.nl/search?hl=nl&q=php+FILTER_VALIDATE_EMAIL+bugs&meta=&aq=f&oq= | ||||||||
Chandler | donderdag 17 december 2009 @ 14:57 | |||||||
quote:Kun je ze dan even laten melden hoe dat dan kan (in hun ogen?) | ||||||||
GlowMouse | donderdag 17 december 2009 @ 14:57 | |||||||
Je moet kijken op http://bugs.php.net/search.php?cmd=display&search_for=+%09FILTER_VALIDATE_EMAIL&x=0&y=0 en daar zie je dat er geen bugs open staan. | ||||||||
hamkaastosti | donderdag 17 december 2009 @ 16:50 | |||||||
quote:mjah.. zijn expression om te checken is ook nog aan de wat simpele kant. Ik zou gewoon filter_var gebruiken. kijk maar eens op regel 475 welke regex php zelf gebruikt http://svn.php.net/viewvc/php/php-src/trunk/ext/filter/logical_filters.c?revision=290791&view=markup [ Bericht 16% gewijzigd door hamkaastosti op 17-12-2009 18:20:50 ] | ||||||||
xaban06 | vrijdag 18 december 2009 @ 16:38 | |||||||
quote:Het is al weer maanden geleden dat hij zoiets gescript heeft, dus hij kon er niet opkomen. Dat was zijn verdediging. | ||||||||
hamkaastosti | zaterdag 19 december 2009 @ 11:25 | |||||||
ik ben me aan het verdiepen in method chaining. Nu wil ik mijn database op de volgende manier aanroepen:
in de database class werkt het zoiets:
Nu werkt dit prima zolang ik maar 1 query heb. Wil ik een tweede query in dezelfde request doen zonder bijvoorbeeld een join terwijl de eerste dat wel had dan wil hij mijn tweede query ook joinen omdat $this->join niet leeg is. hoe los ik dat netjes op? In zend gebruiken ze ook zoiets maar daar zit vast een handigheidje achter [ Bericht 6% gewijzigd door hamkaastosti op 19-12-2009 12:53:47 ] | ||||||||
Chandler | zaterdag 19 december 2009 @ 14:58 | |||||||
quote:const char regexp[] = "/^((\\\"[^\\\"\\f\\n\\r\\t\\b]+\\\")|([A-Za-z0-9_][A-Za-z0-9_\\!\\#\\$\\%\\&\\'\\*\\+\\-\\~\\/\\=\\?\\^\\`\\|\\{\\}]*(\\.[A-Za-z0-9_\\!\\#\\$\\%\\&\\'\\*\\+\\-\\~\\/\\=\\?\\^\\`\\|\\{\\}]*))@((\\[(((25[0-5])|(2[0-4][0-9])|([0-1]?[0-9]?[0-9]))\\.((25[0-5])|(2[0-4][0-9])|([0-1]?[0-9]?[0-9]))\\.((25[0-5])|(2[0-4][0-9])|([0-1]?[0-9]?[0-9]))\\.((25[0-5])|(2[0-4][0-9])|([0-1]?[0-9]?[0-9])))\\])|(((25[0-5])|(2[0-4][0-9])|([0-1]?[0-9]?[0-9]))\\.((25[0-5])|(2[0-4][0-9])|([0-1]?[0-9]?[0-9]))\\.((25[0-5])|(2[0-4][0-9])|([0-1]?[0-9]?[0-9]))\\.((25[0-5])|(2[0-4][0-9])|([0-1]?[0-9]?[0-9])))|((([A-Za-z0-9])(([A-Za-z0-9\\-])*([A-Za-z0-9]))?(\\.(?=[A-Za-z0-9\\-]))?)+[A-Za-z]+))$/D" deze dus kan toch wel beter ? (niet dat ik het kan hoor ) | ||||||||
Chandler | zaterdag 19 december 2009 @ 15:01 | |||||||
quote:Waarom dan niet gewoon 2 losse queries? je wil toch niet alles aan elkaar koppelen? en heb je bv een voorbeeld van 2 queries? | ||||||||
hamkaastosti | zaterdag 19 december 2009 @ 15:08 | |||||||
quote:2 queries: 1 om newsitems op te halen + userinfo van plaatser 1 om reacties op dat nieuwsitem op te halen | ||||||||
Chandler | zaterdag 19 december 2009 @ 17:44 | |||||||
je kunt toch altijd bij ->from() checken of er al een join is gemaakt? indien wel, die legen oid..? | ||||||||
Sitethief | zondag 20 december 2009 @ 00:10 | |||||||
Hamkaastosti, ik zie dat je met PDO werkt, maar waarom voer je dat niet helemaal door, dwz, preparen van SQL statements etc? Of staat dat erwel in? | ||||||||
hamkaastosti | zondag 20 december 2009 @ 12:18 | |||||||
Dat gebruik ik wel. ik kan gewoon
doen en mijn class maakt er vanzelf vraagtekens van die ik met bindvalue bind nadat ik gekeken heb wat voor een type het is en voor een select kan ik simpelweg
toevoegen waarbij hij de array aan de vraagtekens bind.. maar dit gaat dus allemaal nog mis als ik twee queries achter elkaar wil doen. [ Bericht 17% gewijzigd door hamkaastosti op 20-12-2009 12:40:23 ] | ||||||||
Chandler | zondag 20 december 2009 @ 14:13 | |||||||
Dus je doet dan dit bv? $obj->query()->from('tabel', '*')->join('test", 'test.id = tabel.id')->query()->from("tabel1", '*'); ?> | ||||||||
hamkaastosti | zondag 20 december 2009 @ 20:12 | |||||||
nee ik doe
bijvoorbeeld | ||||||||
Chandler | maandag 21 december 2009 @ 12:53 | |||||||
Mag ik vragen naar het voordeel/idee van deze opzet? | ||||||||
Sitethief | dinsdag 22 december 2009 @ 09:32 | |||||||
Deze class werkt momenteel. Maar hoe kan ik hem veiliger maken? Ik kreeg van een collega te horen dat het stukke veilger kan. Maar ik kan moeilijk al die functions private maken ofzo. | ||||||||
hamkaastosti | dinsdag 22 december 2009 @ 09:47 | |||||||
ik snap die die(); elke keer als een field niet klopt niet zo goed. Het lijkt me handiger om gewoon een array met errors bij te houden en een array met gecheckte velden. Die errors gebruik je om je form opnieuw weer te geven met de fout onder elk veld en de array met gecheckte velden gebruik je om je database te vullen. Verder is het handig om trim te gebruiken om per ongeluk ingevulde spaties te verwijderen. Mijn validator gebruikt trouwens op meer plekken filter_var en heeft private functions al required() en length() | ||||||||
Sitethief | dinsdag 22 december 2009 @ 15:06 | |||||||
quote:Je hebt gelijk, ik zou niet zomaar moeten stoppen bij zoiets triviaals als een verkeerd ingevoerd e-mail adres. Het probleem is alleen dat een class bouw die op meerdere plekken gebruikt moet worden en dus niet weet hoe precies de forms er uit gaan zien. En ik ben nog niet zo goed met arrays........... ik vind het maar onhandelbare dingen. Ik kan bijv niet isset() gebruiken om te zien of er errors in de error array zitten. Anyway, de class geeft nu arrays terug. Overigens gebruik ik trim wel, en is bijv de e-mail validator zo simpel omdat dit nog de testfase is, zodra de class werkend is kan ik de validators gaan uitbreiden. (Filter_var vind ik ietsjes beperkt in zijn functionaliteit wbt email, maar het is inderdaad een optie) Dit is voor mij ook de eerste keer dat ik een class schrijf, en ik ben nog maar 4 weekjes met php bezig. Het loopt allemaal nog niet zo vloeiend | ||||||||
hamkaastosti | dinsdag 22 december 2009 @ 15:40 | |||||||
het probleem met het valideren van email is dat je 's werelds beste filter nog om de tuin kunt leiden door gewoon een valide mailadres in te vullen terwijl het adres misschien niet eens werkt. Wil je echt iemands mail aan iets koppelen dan zul je hem een mailtje moeten sturen met een link erin die de gebruiker moet volgen | ||||||||
Sitethief | dinsdag 22 december 2009 @ 15:51 | |||||||
quote:Zelfs dan, je hebt van die tijdelijke e-mailadressen. Maar goed, dit gaat vooral om klantbestanden e.d. dus dit wordt intern gebruikt. | ||||||||
jakees | woensdag 23 december 2009 @ 00:43 | |||||||
Ik ben weer aan het stoeien met php (wat een langdurig gevecht is het). Maar ik heb nu een dropdownbox met daarin bepaalde waardes. Deze waardes representeren verschillende datums in de db. Nu wil ik dat wanneer ik een datum selecteer en op een knop druk dat dat dan een query wordt opgestart met als inputparameter de geselecteerde waarde in de dropdown. Nou is mijn vraag hoe kan ik de geselecteerde waarde in de dropdown ophalen in html? thx alvast. | ||||||||
hamkaastosti | woensdag 23 december 2009 @ 09:16 | |||||||
als het goed is zitten alle waarden van je form in de $_POST array http://www.w3schools.com/php/php_forms.asp | ||||||||
jakees | woensdag 23 december 2009 @ 12:45 | |||||||
quote:Ja daar zitten ze wel in, maar hoe weet je welke de geselecteerde waarde is in de dropdown? | ||||||||
hamkaastosti | woensdag 23 december 2009 @ 12:48 | |||||||
door alle waarden die je in de dropdown ziet ook in value="" te zetten <option value="12-12-2009">12-12-2009</option> | ||||||||
jakees | woensdag 23 december 2009 @ 16:45 | |||||||
quote:thx voor je reactie weer. Mijn code is:
met bovenstaande code wordt de dropdown gepopuleerd. Als ik nu op de knop druk hoe weet ik dan in de 1.php welke optie is gelecteeerd? thx alvast | ||||||||
hamkaastosti | woensdag 23 december 2009 @ 16:52 | |||||||
je bouwt je select niet goed op.
wel erg basic html hoor | ||||||||
hamkaastosti | woensdag 23 december 2009 @ 16:52 | |||||||
ach fuck die kankerhighlighter van fok | ||||||||
jakees | woensdag 23 december 2009 @ 17:04 | |||||||
quote:mijn html is drama ik hebwel een boek gelezen over mysql en php. Mijn website bevat wel wat data maar ik ben er al teringlang mee bezig en snap er nog steeds geen zak van. Zou je me kunnen uitleggen wat ik nu verkeerd doe? Ik wil in principe alleen de geselecteerde waarde van de dropdown doorgeven en vervolgens op basis van de doorgegeven waarde 2 tabellen opbouwen. | ||||||||
hamkaastosti | woensdag 23 december 2009 @ 17:08 | |||||||
een select list is in zijn simpelste vorm: <select> <option value="volvo">Volvo</option> <option value="saab">Saab</option> <option value="mercedes">Mercedes</option> <option value="audi">Audi</option> </select> om de ingevulde waarde in php uit te lezen vul je de eerste regel aan met: <select name="datum"> vervolgens kun je de ingevulde waarde met php uitlezen als $_POST['datum'] | ||||||||
jakees | woensdag 23 december 2009 @ 22:05 | |||||||
quote:thx tosti het werkt! Ik ga nu proberen de includes aan de praat te krijgen. | ||||||||
Tijn | donderdag 24 december 2009 @ 22:47 | |||||||
Hoe skip je een parameter? Ik bedoel dat je bijvoorbeeld wel de 4e parameter aan een functie meegeeft, maar niet de derde. Neem bijvoorbeeld de functie array_slice(). Die heeft twee optionele parameters: de 3e parameter geeft de lengte van de array aan en de 4e parameter geeft aan of je de keys wil behouden of niet. Nou wil ik best de keys behouden, maar de lengte wil ik niet meegeven omdat ik gewoon de hele array tot het einde wil behouden. Ik heb het nu zo opgelost:
Maar eigenlijk is het natuurlijk een beetje schraal zo. Is er een manier om die 3e parameter gewoon te skippen? Ik heb al een paar dingen geprobeerd, maar dit werkt iig allemaal niet:
| ||||||||
Light | donderdag 24 december 2009 @ 23:33 | |||||||
quote:Niet. quote:Als je de vierde parameter wilt meegeven, moet je ook de derde meegeven. Zo staat het ook in de documentatie.
Het stuk tussen [] ($length en $preserve_keys) is optioneel. In dat optionele deel zit ook weer een optioneel deel ($preserve_keys). Om die te kunnen bereiken, moet je dus ook een lengte opgeven. Eigenschap van een loosely typed taal als php is dat je geen overloads kunt gebruiken. Alleen de naam van de functie bepaalt wat er wordt aangeroepen, het type en aantal argumenten niet. Er is vast wel een standaardwaarde voor $length die meegegeven wordt als je het argument niet invult (en dus ook geen preserve_keys gebruikt). Alleen is uit de functiedefinitie hier niet te halen wat die waarde zou moeten zijn. | ||||||||
Tijn | donderdag 24 december 2009 @ 23:37 | |||||||
quote:Jammer | ||||||||
xaban06 | vrijdag 25 december 2009 @ 19:23 | |||||||
Wie kan mij een schop geven in de juiste richting. Ik heb een SELECT query, met LIMIT 10 aan het einde. Dus ik heb altijd 10 'rows'. Dit moet ik wegschrijven naar bestand.txt, echter wel op een bepaald volgorde, namelijk: var content=new Array() content[0]='data row 1' content[1]='data row 3' content[2]='data row 5' content[3]='data row 7' content[4]='data row 9' var content2=new Array() content2[0]='data row 2' content2[1]='data row 4' content2[2]='data row 6' content2[3]='data row 8' content2[4]='data row 10' Hoe kan ik dit het beste aanpakken? | ||||||||
GlowMouse | vrijdag 25 december 2009 @ 20:19 | |||||||
quote:Tenzij je resultset minder dan 10 rijen heeft. En dat los je op door twee keer door de array met resultaten te lopen met een for-loop. | ||||||||
Tijn | zaterdag 26 december 2009 @ 01:46 | |||||||
quote:Zoiets?
| ||||||||
GlowMouse | zaterdag 26 december 2009 @ 01:49 | |||||||
arrays beginnen in PHP met 0 | ||||||||
Tijn | zaterdag 26 december 2009 @ 01:52 | |||||||
quote:Ja okay, maar omdat in het voorbeeld van xaban06 zijn "data rows" bij 1 begonnen, dacht ik: dat hou ik dan ook maar even aan. Het gaat om het idee he | ||||||||
hamkaastosti | zaterdag 26 december 2009 @ 12:29 | |||||||
ik heb weer een vraag over mijn mvc gepruts. de basis heb ik nu in zo'n beetje in orde maar hoe maak je op een handige manier een administrator gedeelte waarbij je toch bij je controllers en models kunt? Je hele mvc structuur nog een keer kopiëren naar een /admin map lijkt me ook niet handig maar /admin/news/write oid route ook niet naar de juiste plek. halp? | ||||||||
jakees | zaterdag 26 december 2009 @ 14:21 | |||||||
hallo, ik probeer te werken met PHP_SELF maar het lukt niet erg. Ik heb de volgende code:
Als ik de action laat staan krijg ik een lege pagina. Wanneer ik de code
thx alvast. | ||||||||
jakees | zaterdag 26 december 2009 @ 23:54 | |||||||
quote:al opgelost.Ik weet niet precies wat foutzat. Ik denk dat er een quotje fout stond of zo. | ||||||||
wobbel | zondag 27 december 2009 @ 19:18 | |||||||
Oke, deze is voor mij lastig en ik kom er ook niet uit Ik ben een CMS systeem aan het bouwen die met nette pagina url's overweg kan (bijv. http://www.example.com/grafisch/folders/verspreiding) Dit krijg ik voor elkaar dmv een hierarchische tabel (als ik het zo goed spel ) Hiervoor heb ik gebruik gemaakt van de volgende tutorial op mysql.com => http://dev.mysql.com/tech(...)erarchical-data.html Alleen loop ik nu tegen een probleem aan, er kunnen geen dubbele namen aanwezig zijn (in de tutorial is het de veld "name"). Hoe los ik dat op? http://www.example.com/grafisch/folders/verspreiding kan dus wel, maar http://www.example.com/overig/verspreiding kan niet omdat verspreiding al gebruikt is als "name" en dubbele names dan loopt de boel zeg maar vast | ||||||||
Tuvai.net | zondag 27 december 2009 @ 19:21 | |||||||
quote:Je hoort zo'n unique constraint in dit geval dan ook te leggen op de combinatie Parent ID + Naam i.p.v. alleen Naam. Je wilt immers toch de unieke namen per parent. | ||||||||
wobbel | zondag 27 december 2009 @ 19:26 | |||||||
quote:Maar hoe ga ik dat doen met SQL dan? Ik doe het nu namelijk inderdaad met alleen de "Naam" Voorbeeld:
| ||||||||
xaban06 | maandag 28 december 2009 @ 01:00 | |||||||
Voor mijn 'lastonline' field gebruik het volgende formaat: JaarMaandDagUurMinuut Een voorbeeld zou zijn: 200929120105 (29 december 2009, 01:05). Hoe is het mogelijk om na te gaan hoe die field 10 minuten terug er uit zou zien? Ik weet het, ik heb voor een foute formaat gekozen | ||||||||
PiRANiA | maandag 28 december 2009 @ 01:02 | |||||||
quote:Eerst met een regex de datum er uit halen, dis via strtotime omzetten in een unix time string, daar het aantal seconden af halen, en dan weer via date omzetten naar je formaat? | ||||||||
Tijn | maandag 28 december 2009 @ 01:03 | |||||||
Ik zou 'em door strtotime() gooien zodat je er een normale timestamp uit krijgt. Daar haal je dan 10*60 vanaf en stop je vervolgens in date() om er weer dat dwaze formaat van je van te fabriceren. | ||||||||
GlowMouse | maandag 28 december 2009 @ 01:07 | |||||||
mktime ligt meer voor de hand | ||||||||
xaban06 | maandag 28 december 2009 @ 01:20 | |||||||
quote:Ik heb het gevonden, het kan makkelijker! date('YmdHi', strtotime('-10 minutes')); | ||||||||
Tijn | maandag 28 december 2009 @ 01:21 | |||||||
quote:Maar dat is op basis van de huidige tijd, niet op basis van de tijdstring die je al hebt. | ||||||||
xaban06 | maandag 28 december 2009 @ 01:24 | |||||||
quote:Mja, mijn fout Verkeerd uitgelegt. Ik moet met een script kunnen zien hoeveel online gebruikers er op het moment (afgelopen 10 min) zijn. | ||||||||
Tijn | maandag 28 december 2009 @ 01:25 | |||||||
quote: | ||||||||
Light | maandag 28 december 2009 @ 07:17 | |||||||
quote:Da's niet hetzelfde formaat als in je voorbeeldstring 200929120105, dat was YdmHi. | ||||||||
Chandler | maandag 28 december 2009 @ 20:39 | |||||||
Ik zit met een vraagje over een session file; opeens had een project van mij en error als ik session_start() gebruikte, inden ik deze remarkte werkte het project naar behoren zonder sessies. Omdat ik het probleem nogal raar vond heb ik mijn sessies folder bekeken en toen ik 1 sessie verwijderde werkte het project weer met session_start Nu is deze sessie gemaakt door het project dus vraag ik mij af hoe het in vredus naam mogelijk is om een sessie te vergallen waardoor de scripting niet meer werkt. Mijn sessie:
Kan iemand mij vertellen wat hier fout in is? (deze is trouwens gemaakt door php zelf) (sess_8oum6stpbs14it1kn2g93bms03) Tnx! [edit]enters ivm leesbaarheid[/edit] | ||||||||
xaban06 | dinsdag 29 december 2009 @ 14:28 | |||||||
quote:Spelfoutje Ik ben een poll applicatie aan het schrijven, hiervoor gebruik ik 3 tabellen: Poll - id - user_id (verschillende gebruikers kunnen poll's aanmaken) - question - show Poll_answers - id - poll_id - answer - points Poll_log - id - poll_id - IP Is dit handig? Of kan het veel logischer/compacter? | ||||||||
Chandler | dinsdag 29 december 2009 @ 20:31 | |||||||
lijkt me erg goed; gebruik zo'n opzet voor www.gfxpoll.nl en natuurlijk www.gfxpoll.com al zou ik je wel aanraden als je echt de database wilt optimaliseren het best handig is om een apparte tabel te gebruiken voor het ip adres en deze in je poll_log tabel te verbinden middels een ID, scheelt ietsje pietsje data. | ||||||||
hamkaastosti | dinsdag 29 december 2009 @ 20:59 | |||||||
de indeling van je tabellen daargelaten vind ik je naamgeving raar. Bij een poll geef je geen points en een answer maar kies je een option dmv een vote oid en ook de id bij je poll_log lijkt me niet echt nodig.. je selecteer rijen in die tabel op poll_id of op ip en als je een poll verwijderd kun je dat log ook leeggooien door alle rijen met het poll_id of 1 rij dmv van het ip | ||||||||
xaban06 | dinsdag 29 december 2009 @ 21:38 | |||||||
quote:Ik geef aan iedere record altijd een unieke ID mee, of het nou wel of niet noodzakelijk is. Stiekem denk ik daar eigelijk niet over na. Ik vind points juist wel een goede benaming, je kan voten op een 'answer', deze punten moeten ergens geteld worden. | ||||||||
xaban06 | dinsdag 29 december 2009 @ 21:38 | |||||||
quote:Leuke website! Nice | ||||||||
DaFan | woensdag 30 december 2009 @ 08:46 | |||||||
SQL: Ik heb een 20-tal databases, en deze bevatten allen exact dezelfde tabellen (met andere informatie). Er is een tabel die ik heb gemaakt in DB 005, en die wil ik kopiëren naar alle andere databases. Ik heb er 10 gedaan met de volgende statement:
Gaat allemaal goed, tot de laatste 10, daar krijg ik foutmelding:
Enig idee? ;( | ||||||||
ursel | woensdag 30 december 2009 @ 08:48 | |||||||
quote:Controlleer je veld types eens, ziet er naar uit dat je daart een verschil in hebt | ||||||||
DaFan | woensdag 30 december 2009 @ 08:52 | |||||||
Hm kan het ermee te maken hebben dat de kolommen in de laatste 10 tabellen 'verkeerd' staan? Zeg maar in DB 005 is het A B C D en in (bv) DB 022 en verder is het A B D C | ||||||||
ursel | woensdag 30 december 2009 @ 08:54 | |||||||
quote:Yup, met de select * geef je die volgorde direct door aan je insert into. | ||||||||
DaFan | woensdag 30 december 2009 @ 08:56 | |||||||
Ah vandaar, lekker vaag dan. Maarja dan de volgende vraag natuurlijk; Kan ik er ook voor zorgen dat er naar de kolomnaam wordt gekeken en aan de hand daarvan de tabel wordt gekopieerd? Of kan ik zelf de kolommen verplaatsen in de juiste volgorde? Edit; ik kan wel de kolommen zelf verplaatsen zie ik nu, maar mag de table niet droppen en recreaten. En dat is wel nodig volgens MS. | ||||||||
ursel | woensdag 30 december 2009 @ 09:02 | |||||||
Je kan natuurlijk ook ipv select * de kolom volgorde in je select zetten | ||||||||
DaFan | woensdag 30 december 2009 @ 09:10 | |||||||
quote:Fantastisch, het werkt Bedankt Exact Software...opbouw van de tabel verschilt onderling 4x in 36 databases, knap werk | ||||||||
PiRANiA | woensdag 30 december 2009 @ 18:52 | |||||||
Servertje heeft het zwaar | ||||||||
Tuvai.net | woensdag 30 december 2009 @ 19:02 | |||||||
quote:Sorry, moest effe mijn nieuwste botje testen. | ||||||||
PiRANiA | woensdag 30 december 2009 @ 19:17 | |||||||
quote:Test geslaagd | ||||||||
GlowMouse | woensdag 30 december 2009 @ 19:19 | |||||||
quote:waaruit blijkt dat? | ||||||||
PiRANiA | woensdag 30 december 2009 @ 19:28 | |||||||
quote:Jij zal het niet veel vinden (als je de FOK! stats hebt gezien), maar ik vind 60 queries per seconde vrij veel | ||||||||
Tuvai.net | woensdag 30 december 2009 @ 19:29 | |||||||
quote:Ik was eigenlijk meer aan het kijken naar je 'Failed attempts". 60 queries per seconden vind ik niet zo heel gek veel, meer dan 1000 failed connection attempts in een uur tijd echter wel. | ||||||||
PiRANiA | woensdag 30 december 2009 @ 19:37 | |||||||
quote:Hoe kom ik er achter waar het fout gaat? | ||||||||
GlowMouse | woensdag 30 december 2009 @ 19:41 | |||||||
quote:Voor je bezoekersteller mag je wel trots zijn (mits redelijk aantal queries per pagina), maar je had het erover dat hij het druk had. En dat is niet zo, een moderne thuis-pc kan rustig 50-100k queries/seconde uitvoeren primary key look-ups wel. quote:tcpdump | ||||||||
PiRANiA | woensdag 30 december 2009 @ 19:43 | |||||||
quote:Het zijn allemaal lokale scripts met data uit metingen. Tcpdump werkt dan niet denk ik? En qua bezoekers: 1 dus, alleen ik zelf | ||||||||
PiRANiA | woensdag 30 december 2009 @ 20:30 | |||||||
GM, hij heeft het inderdaad niet echt druk: | ||||||||
GlowMouse | woensdag 30 december 2009 @ 20:33 | |||||||
20GB geheugen? | ||||||||
PiRANiA | woensdag 30 december 2009 @ 22:35 | |||||||
quote:Jup, chille x2200 server. Ik moet hem alleen nog ergens weghangen eigenlijk, maar colocatie is vrij duur | ||||||||
GlowMouse | woensdag 30 december 2009 @ 22:54 | |||||||
ic; heb je zo'n enorm kleine dataset of heb je MySQL nog met de default config draaien? | ||||||||
PiRANiA | woensdag 30 december 2009 @ 22:57 | |||||||
quote:Relatief veel data (~200MB database) op standaard configuratie... | ||||||||
GlowMouse | woensdag 30 december 2009 @ 22:59 | |||||||
zonde! | ||||||||
ursel | donderdag 31 december 2009 @ 09:07 | |||||||
quote:Ben ik wel benieuwd met welke settings je dat beter kan optimaliseren als je veel data hebt. | ||||||||
ursel | donderdag 31 december 2009 @ 09:19 | |||||||
Overigens zelf ook een vraag wat te maken heeft met afronding. :{ Op 2 plaatsen wordt min of meer een identieke berekening gedaan, waarbij de 2e een controle is over de getallen van de eerste. Na wat dumps krijg ik de volgende output bij berekening 1: (QuotaAmount 1 is voor eerste berekening) QuotaAmount 1 : 43.575, type : double. QuotaAmount 2 : 43.57, type : string. QuotaAmount 3 : 43.57, type : double.
Vervolgens doe ik verderop een nieuwe berekening en krijg ik de volgende output: a 1: 43.575, type : double. a 2: 43.58, type : string. a 3: 43.58, type : double. En hier de code:
Iemand enig idee hoe ik ervoor kan zorgen dat ze beide correct afgerond worden, of hoe en waar ut verkeerd gaat? :? | ||||||||
Tijn | donderdag 31 december 2009 @ 10:15 | |||||||
Ik denk dat het verkeerd gaat omdat je floats gebruikt. Floats hebben van zichzelf al problemen met afronden. | ||||||||
hamkaastosti | donderdag 31 december 2009 @ 10:22 | |||||||
als het bedragen zijn waarmee je werkt kun je volgens mij beter met integers en centen werken en pas helemaal op het eind gaan afronden | ||||||||
ursel | donderdag 31 december 2009 @ 10:28 | |||||||
Mja, maar de afronding gaat al verkeerd in de sprintf | ||||||||
Tijn | donderdag 31 december 2009 @ 10:32 | |||||||
quote:Omdat je daar er ook al een float van maakt. Floats zijn niet altijd precies het getal die je bedoelt. | ||||||||
ursel | donderdag 31 december 2009 @ 10:57 | |||||||
quote:aah, wacht, die sprintf maakt er ook float van. Gewoon even nieuwsgierig, maar wat is eigenlijk het nut van een float als je die niet precies het getal is dat je bedoeld? | ||||||||
Tijn | donderdag 31 december 2009 @ 11:05 | |||||||
quote:Het handige van een float is dat je zowel extreem grote als extreem kleine getallen erin kunt opslaan. Andere types hebben harde limieten, zoals bv een int die van -2147483648 t/m 2147483647 werkt. Een float heeft dat soort grenzen niet echt, daar kun je honderd cijfers voor of achter de komma bij zetten en je krijgt nog een waarde eruit die (min of meer) lijkt op wat je bedoelde. | ||||||||
GlowMouse | donderdag 31 december 2009 @ 11:53 | |||||||
quote:Sowieso overstappen op InnoDB, beetje recente versie pakken (5.4/5.5), en dan spelen met de buffer pool, en logbuffer. | ||||||||
ursel | donderdag 31 december 2009 @ 12:06 | |||||||
Kijk, 2 mooie posts waar ik volgend jaar eens ff mooi naar ga kijken. | ||||||||
PiRANiA | donderdag 31 december 2009 @ 12:40 | |||||||
quote:Heb je daar een mooie guide voor? Of een leidraad waar ik kan beginnen? | ||||||||
GlowMouse | donderdag 31 december 2009 @ 12:41 | |||||||
Zoeken op http://www.mysqlperformanceblog.com/ | ||||||||
Xcalibur | donderdag 31 december 2009 @ 12:42 | |||||||
Hee, dit topic was ik kwijt | ||||||||
GlowMouse | donderdag 31 december 2009 @ 12:42 | |||||||
http://www.mysqlperforman(...)db_buffer_pool_size/ http://www.mysqlperforman(...)-pool-always-better/ http://www.mysqlperforman(...)-after-installation/ | ||||||||
ursel | donderdag 31 december 2009 @ 12:50 | |||||||
Even de posts gebookmarked | ||||||||
PiRANiA | donderdag 31 december 2009 @ 13:00 | |||||||
quote:Oeh leuk materiaal om naar te kijken. Ik ben nu mijn grootste tabel aan het omzetten naar InnoDB: -edit- nog steeds bezig -edit2- Ik zie die innodb setting snergens in mijn standaard config file? /etc/mysql/my.cnf, kan ik ze gewoon toevoegen of staan ze ergens anders? -edit3- Hij is nu al bijna 40 minuten bezig met 1 table... [ Bericht 4% gewijzigd door PiRANiA op 31-12-2009 13:35:59 ] | ||||||||
PiRANiA | donderdag 31 december 2009 @ 13:53 | |||||||
Dat is wel apart, elke refresh staat er een ander aantal rows | ||||||||
PiRANiA | donderdag 31 december 2009 @ 14:28 | |||||||
Hmm ik heb nogal wat problemen gehad met de innodb settings Corrupte bestanden en such. Hij lijkt mijn innodb settings niet te pakken? Misschien zet ik ze verkeerd neer? Mogelijk heeft iemand een voorbeeldconfiguratie voor me? | ||||||||
GlowMouse | donderdag 31 december 2009 @ 14:32 | |||||||
Gewoon toevoegen (/etc/mysql/my.cnf) en mysql herstarten innodb_buffer_pool_size= 1000M Die rowcount is innodb-eigen, zie manual. | ||||||||
PiRANiA | donderdag 31 december 2009 @ 14:43 | |||||||
quote:Ahja, dat werkt. Ik kreeg eerst errors over corrupte bestanden et cetera (uiteraard gebackupped, maar niet nodig). Je hoeft dus niet alle settings te setten begrijp ik -edit- Mijn count(*) over 2.5M rows tabel duurt nu wel 10 keer langer ofzo | ||||||||
GlowMouse | donderdag 31 december 2009 @ 15:00 | |||||||
Bij FOK! scheelt dat wel een miljoen keer (of 10 miljoen miljard keer); de kunst is dan ook om nooit/niet vaak een count op een hele tabel te doen. | ||||||||
ursel | donderdag 31 december 2009 @ 15:06 | |||||||
quote:je moet een count door php laten uitvoeren dan? | ||||||||
GlowMouse | donderdag 31 december 2009 @ 15:07 | |||||||
quote:wanneer wil je nou ooit weten hoeveel rijen een tabel heeft? | ||||||||
Tuvai.net | donderdag 31 december 2009 @ 15:09 | |||||||
quote:Best vaak hoor. Al dan niet met een GROUP BY. | ||||||||
PiRANiA | donderdag 31 december 2009 @ 15:09 | |||||||
quote:Ik wil weten hoe de opbouw van sommige data verloopt, dan vind ik het wel intereressant om te weten hoe veel gegevens ik al heb | ||||||||
GlowMouse | donderdag 31 december 2009 @ 15:11 | |||||||
quote:We hadden het over een SELECT count(*) FROM tbl, niet over een andere query. quote:dat is een query'tje per maand ofzo, /care. | ||||||||
ursel | donderdag 31 december 2009 @ 15:13 | |||||||
quote:Een hoop van onze tabellen staan gelijk aan het aantal producten en of objecten. Daarnaast voor het aangeven van hoeveel pagina's er zijn in de lijst navigatie. Dus redelijk vaak eigenlijk nog wel. | ||||||||
GlowMouse | donderdag 31 december 2009 @ 15:14 | |||||||
quote:En dan staat er nooit in WHERE bij? En dit zijn ook typisch dingen die je denormaliseert. quote:http://www.mysqlperforman(...)-paginated-displays/ | ||||||||
Tuvai.net | donderdag 31 december 2009 @ 15:17 | |||||||
quote:Ja, doh. Toen vroeg jij hoe vaak je dat wel niet doet, waarom ik (en zo te zien andere ook) reageer dat ik dat dus wel eens nodig heb. @PiRANiA: COUNT(*) op tabellen zonder een WHERE clausule is in InnoDB nou eenmaal erg traag (in vergelijking met bijv. MyISAM). Probeer anders een index in je query te definiëren. En nog beter, optimaliseer je databasestructuur (correcte indexes leggen), maar dat dien je sowieso te doen (niet alleen in geval van InnoDB). | ||||||||
ursel | donderdag 31 december 2009 @ 15:19 | |||||||
quote:ik zeg verder niet dat onze code perfect is Verre van zelfs, alleen dat we de count wel vaak gebruiken. Hopelijk in feb start maken met nieuwe basis voor het extranet Dus al dit soort zaken is goed om mee te nemen | ||||||||
GlowMouse | donderdag 31 december 2009 @ 15:20 | |||||||
quote: | ||||||||
qu63 | zaterdag 2 januari 2010 @ 23:57 | |||||||
Jeej, eerste vraag in het nieuwe jaar! *O*
Ik kan niet bij mn php.ini, maar heb wel dit gevonden: http://www.verysimple.com(...)ference-in-htaccess/ .htacces bestand in wwwroot/syncml/syncml gegooid en in wwwroot maar ik blijf die melding krijgen. php.net geeft ook geen alternatief voor bijvoorbeeld xml_parse_into_struct(). Iemand enige idee wat ik wel kan doen? | ||||||||
GlowMouse | zaterdag 2 januari 2010 @ 23:58 | |||||||
waarom ampersandjes? | ||||||||
qu63 | zondag 3 januari 2010 @ 00:02 | |||||||
quote:Huh? | ||||||||
GlowMouse | zondag 3 januari 2010 @ 00:05 | |||||||
C:\domains\svenahrens.nl\wwwroot\syncml\syncml\syncml.php on line 222 bijvoorbeeld | ||||||||
GlowMouse | zondag 3 januari 2010 @ 00:06 | |||||||
xml_parse_into_struct ( resource $parser , string $data , array &$values [, array &$index ] ) dat gaat al goed, bij de functieaanroep zijn geen ampersands nodig | ||||||||
qu63 | zondag 3 januari 2010 @ 00:06 | |||||||
quote:Ga ik eens kijken of die weg te halen zijn en of het dan wel werkt.. | ||||||||
qu63 | zondag 3 januari 2010 @ 00:11 | |||||||
quote:In de code staan de ampersands er ook niet.. xml.php regels 160-164
| ||||||||
GlowMouse | zondag 3 januari 2010 @ 00:12 | |||||||
&$values? | ||||||||
qu63 | zondag 3 januari 2010 @ 00:13 | |||||||
quote:bugger.. * qu63 glas wegzet | ||||||||
qu63 | zondag 3 januari 2010 @ 00:19 | |||||||
Thanks, error's zijn weg! (Heb overal de &$ vervangen door $) Helaas werkt mn sync-profiel op mn telefoon nog niet, maar dat is geen php/sql-vraag | ||||||||
Sitethief | maandag 4 januari 2010 @ 08:19 | |||||||
Deze functie geeft altijd een false weer, ook al zit er een cijfer in.... Hij werkt ook niet als ik
gebruik en de true en false omdraai. Wat doe ik fout? | ||||||||
Tijn | maandag 4 januari 2010 @ 08:51 | |||||||
Waarom gebruik je niet gewoon is_numeric()? | ||||||||
FastFox91 | maandag 4 januari 2010 @ 08:57 | |||||||
quote:Of eventueel ctype_digit? | ||||||||
Xcalibur | maandag 4 januari 2010 @ 09:18 | |||||||
wat doet $this->StripSingle ? | ||||||||
Sitethief | maandag 4 januari 2010 @ 09:30 | |||||||
Als ik ctype_digit gebruik dan krijg ik False terug, terwijl ik "0" als waarde meegeef. Het nadeel van deze functions is dat ik er bijv later geen telefoonnummer mee kan valideren, terwijl dat met preg_match wel kan.
| ||||||||
Sitethief | maandag 4 januari 2010 @ 09:32 | |||||||
ik kan natuurlijk voor telefoonnummers numbers_only() gebruiken om de streepjes etch eruit te halen. Edit: ik zie net dat dat een zelfgebouwde function is... die toch weer teruggrijpt op preg_match. | ||||||||
Sitethief | maandag 4 januari 2010 @ 09:40 | |||||||
quote:
| ||||||||
Sitethief | maandag 4 januari 2010 @ 11:16 | |||||||
Dit werkt overigens ook niet, de string word niet gestript van niet nummerieke karakters..... [ Bericht 4% gewijzigd door Sitethief op 04-01-2010 13:08:33 (nieuwe code) ] | ||||||||
hamkaastosti | maandag 4 januari 2010 @ 12:40 | |||||||
dwing je gebruikers gewoon een correct telefoonnummer in te voeren door bijvoorbeeld een kengetal en abonneeveld te gebruiken die je zelf aan elkaar plakt of geef bij je form een voorbeeld hoe het ingevuld moet worden met evt clientside javascript validatie. je kunt met php dan simpelweg ctype_digit gebruiken voor de check.quote: | ||||||||
Light | maandag 4 januari 2010 @ 13:04 | |||||||
quote:Alleen cijfers voor een telefoonnummer is niet handig. Het kan ook gebeuren dat iemand een internationaal telefoonnummer wil invoeren, dan heb je in ieder geval een + nodig als eerste teken. Dan maak je het met 2 velden (netnummer en abonneenummer) niet handiger. | ||||||||
Sitethief | maandag 4 januari 2010 @ 13:11 | |||||||
quote:Dit moet een validation class worden die voor meerdere omgevingen te gebruiken is. Dwz dat telefoon nummers erg kunnen verschillen omdat de programmatuur voor diverse landen gebruikt kan worden. quote:Waarom heb je dan een plus nodig? Je schrijft toch gewoon 0031384202277 en niet +31384202277 | ||||||||
ursel | maandag 4 januari 2010 @ 13:20 | |||||||
quote:Jij misschien, maar je gebruikers zullen het op alle mogelijke manieren proberen... | ||||||||
Tijn | maandag 4 januari 2010 @ 13:24 | |||||||
quote:Ik denk dat meer mensen +31 invoeren dan 0031. | ||||||||
Light | maandag 4 januari 2010 @ 13:27 | |||||||
quote:Maar je weet niet waar iemand vandaan gaat bellen, en 00 is niet overal de code voor internationaal bellen. De + bij een telefoonnummer wordt wel algemeen herkend als "bel internationaal", waarbij de beller dan zelf kan uitzoeken wat de goede code is voor het land waar hij zich bevindt. Of dat 00, 011, 09, 9, 990 of nog iets anders is, is niet jouw probleem. | ||||||||
Sitethief | maandag 4 januari 2010 @ 13:33 | |||||||
En dan geef ik ze een foutmelding waarin nóg eens duidelijk uitgelegd staat hoe het moet. naast dat dat bij de invoer al stond natuurlijk. Het is namelijk niet de bedoeling dat gebruikers van alles en nog wat in de database gaan gooien wat er dna later weer uitgefilterd kan worden. | ||||||||
Sitethief | maandag 4 januari 2010 @ 13:37 | |||||||
quote:Ik heb het nooit gebruikt . Maar ja, wie ben ik? quote:Ik kan dus net zo goed die + in mijn database zetten. Maar goed, de functie werkt nu al niet...... edit: Als ik in de RegEx tester
gebruik om
Te strippen, dan werkt het. Ik krijg dan:
Maar in mijn code niet. [ Bericht 11% gewijzigd door Sitethief op 04-01-2010 13:47:40 ] | ||||||||
Sitethief | maandag 4 januari 2010 @ 15:12 | |||||||
Zo werkt ie. Het zat em in de $inputValidateTel = preg_replace('/[^0-9\+\-]/', '',$inputValidateTel); | ||||||||
Tijn | maandag 4 januari 2010 @ 15:15 | |||||||
Ik zou de naam van de functie veranderen in "sanitize" in plaats van "validate". Als je alleen zou valideren, zou je alleen een true / false antwoord verwachten, maar in dit geval pas je de string ook echt aan. | ||||||||
Sitethief | maandag 4 januari 2010 @ 15:43 | |||||||
quote:Klopt | ||||||||
Tegan | maandag 4 januari 2010 @ 17:27 | |||||||
Newb-vraag. Ik heb een array en een variabele, hoe kan ik checken of die variabele in de array voorkomt? Bv. $array = array(1, 3, 7); $var = 1; | ||||||||
GlowMouse | maandag 4 januari 2010 @ 17:28 | |||||||
in_array | ||||||||
Trollface. | maandag 4 januari 2010 @ 17:29 | |||||||
quote:
| ||||||||
Tegan | maandag 4 januari 2010 @ 17:30 | |||||||
Thanks, met Google kwam ik alleen dingen tegen die checken of een var een array is of niet . | ||||||||
GlowMouse | maandag 4 januari 2010 @ 17:31 | |||||||
de functienaam daarvoor verschilt ook maar een letter | ||||||||
GlowMouse | maandag 4 januari 2010 @ 17:35 | |||||||
Die manual is trouwens wel handig, want links staan alle arrayfuncties. Om de zoveel tijd moet je die allemaal doorlopen om te kijken wat er allemaal mogelijk is. | ||||||||
Sitethief | maandag 4 januari 2010 @ 17:38 | |||||||
quote:Ik struikel er alleen vaak over dat op die website de voorbeelden altijd erg complex zijn en je dus moeilijk kunt achterhalen hoe je een function simpel kunt gebruiken. Zeker als je net begonnen bent met php. Verder worden veel dingen nogal summier uitgelegd. | ||||||||
GlowMouse | maandag 4 januari 2010 @ 17:44 | |||||||
quote:Als je wat ervaring hebt, kun je de voorbeelden wel waarderen. | ||||||||
Trollface. | maandag 4 januari 2010 @ 17:46 | |||||||
quote:Agreed, die voorbeelden kunnen soms erg fijn zijn. | ||||||||
Sitethief | dinsdag 5 januari 2010 @ 11:22 | |||||||
Hoe kun je simpel in multidimensionale arrays zoeken? | ||||||||
GlowMouse | dinsdag 5 januari 2010 @ 12:02 | |||||||
http://nl.php.net/manual/en/function.array-search.php de comments zijn ook bruikbaar, al staat er soms wat heel erg doms tussen. | ||||||||
Trollface. | dinsdag 5 januari 2010 @ 12:31 | |||||||
quote:
Voorbeeld:
Output:
Zoiets? $return[0] is de key in de eerste array, $return[1] in de tweede. | ||||||||
Sitethief | dinsdag 5 januari 2010 @ 14:32 | |||||||
Wat vinden jullie beter. Het checken van een wachtwoord bij het inloggen dmv WHERE statement in een query, of door een SELECT query te doen en dan het wachtwoord de controleren in die array. De query methode is sneller en korter, maar levert gevaar op omdat je een query runt. De array methode is veiliger, maar langzamer en langer. Ook is het minder veilig om wachtwoorden heen en weer te sturen tussen classes waarin je de array afcheckt. | ||||||||
Tijn | dinsdag 5 januari 2010 @ 14:43 | |||||||
quote:Ik zou zorgen dat je queries zoveel mogelijk outputten wat je hebben wil. Als je wil controleren of een password met een username matcht, kan dat prima met een SELECT en een WHERE. Dan hoef je niet later door je resultaten te gaan zitten graven, maar heb je gelijk wat je hebben wil. Qua veiligheid maakt het toch niet zoveel uit hoe je het aanpakt? Wel moet je natuurlijk zorgen dat je je passwords encrypt en dat je de inputstrings escaped voordat je ze in de query plakt om injecties te voorkomen. | ||||||||
GlowMouse | dinsdag 5 januari 2010 @ 14:45 | |||||||
Als je password een hash is waarvan de salt nog onbekend is op het moment dat je de query uitvoert, en je hashmethode geen MySQL-functie is, zou ik toch voor de check in php gaan. | ||||||||
Sitethief | woensdag 6 januari 2010 @ 10:48 | |||||||
http://pastebin.com/f212e15f4 Deze code werkt, maar zou het nog beter/anders kunnen en waarom? Ik ben net begonnen met leren over cookies en sessions. Edit: de Secure class: http://pastebin.com/f327ce69e [ Bericht 11% gewijzigd door Sitethief op 06-01-2010 11:50:50 ] | ||||||||
Trollface. | woensdag 6 januari 2010 @ 16:45 | |||||||
quote:Ik zou de databaseconfig in een apart bestand zetten. Ook zou ik als ik jou was een duidelijke scheiding gebruiken tussen de PHP-code die dingen aanroept en HTML-code met PHP-code ertussen die de opgehaalde gegevens d.m.v. een foreach o.i.d. weergeeft. Ongeveer dit dus (erg simpel geschreven, persoonlijk gebruik ik liever frameworks en classes, maar dit werkt als voorbeeld goed ):
| ||||||||
Intrepidity | donderdag 7 januari 2010 @ 16:40 | |||||||
Ik ben bezig met het schrijven van een kleine wrapperklasse om fgetcsv heen om makkelijk met csv bestanden om te gaan. Nou moet de fgetcsv functie o.a. weten wat het veldscheidingsteken is, of er aanhalingstekens e.d. om de waarden heenzitten en met welk karakter er ge-escaped wordt. Is er ook een manier om dat handig zelf te analyseren? Het wordt gebruikt in een open webapplicatie waarbij helemaal niet zeker is in welke CSV-indeling mensen dingen gaan uploaden. | ||||||||
wobbel | donderdag 7 januari 2010 @ 23:02 | |||||||
Ben op dit moment bezig met een simpel factuur systeem in PHP, alleen nu wil ik ook herhalende/reperterende facturen. Hoe kan ik dat het beste doen? | ||||||||
Tuvai.net | donderdag 7 januari 2010 @ 23:15 | |||||||
Voor herhalende / automatische handelingen, zou ik om te beginnen eens kijken naar cronjobs. En of je daar überhaupt de mogelijkheid voor hebt natuurlijk. [ Bericht 14% gewijzigd door Tuvai.net op 07-01-2010 23:22:14 ] | ||||||||
wobbel | vrijdag 8 januari 2010 @ 00:33 | |||||||
quote:Ja, heb volledige shell toegang als root dus dat is niet het probleem Maar hoe doe ik dat met MySQL en PHP? Hoe zorg ik ervoor dat er wekelijks of maandelijks een factuur wordt gegenereerd voor onbepaalde of bepaalde periode | ||||||||
Xcalibur | vrijdag 8 januari 2010 @ 08:37 | |||||||
Een cronjob maken die 1x per week of 1x per maand draait En die dus de facturen maakt... | ||||||||
Xcalibur | vrijdag 8 januari 2010 @ 08:43 | |||||||
quote:Ik heb ook zoiets gemaakt, daarbij zet ik de instellingen op de default waarde en geef ik een preview van het bestand na het inlezen. Als het niet goed is kan je de defaultinstellingen wijzigen en het nog een keer proberen... Om het veldscheidingsteken automatisch te bepalen zou je moeten tellen hoevaak een komma of puntkomma op een regel voorkomt, en of dat op iedere regel is? Wordt wel een gedoe denk ik... | ||||||||
Tuvai.net | vrijdag 8 januari 2010 @ 12:25 | |||||||
quote:Inderdaad niet meer van een kwestie van je code in een cronjob zetten die om de zoveel tijd draait. Vrijwel hetzelfde als wat je in Windows doet met executables en geplande taken / scheduled tasks. | ||||||||
Portugalia | vrijdag 8 januari 2010 @ 13:11 | |||||||
Een vraag van een hobby-websitemaker: Ik heb een homepage gemaakt in HTML en geupload naar mijn domein, werkt goed. Ondertussen heb ik een andere site gemaakt met wordpress.com, werkt ook goed, ben eigenlijk wel enthousisast over wordpress. Nu zie ik op mijn provider-site dat ik mijn pack kan upgraden zodat ik mijn homepage onder wordpress.org kan gaan draaien (met database SQL ed, heb ik nog niet eerder mee gewerkt overigens). Wordpress.org biedt meer mogelijkheden dan wordpress.com, klopt dat? Voordeel is dat ik dan én via wordpress werk, en mijn domeinnaam kan houden. Nadeel, ik moet een duurder pack gaan betalen, terwijl mijndomein.wordpress.com gratis is. Ik kan ook mijn domein door laten linken naar de wordpress.com pagina, maar in dat geval denk ik erover om mijn domeinnaam op te geven en alleen maar de wordpress.com te nemen. Wat is wijsheid? | ||||||||
Tijn | vrijdag 8 januari 2010 @ 13:13 | |||||||
Doorlinken van domeinen is troep waar je niet aan wil beginnen. Ik zou die upgrade doen. Zo duur kan het toch niet zijn? En als het wel duur is, zoek je een provider die minder duur is, want er zijn onwijs veel hosts te vinden die PHP en MySQL aanbieden natuurlijk. | ||||||||
Intrepidity | vrijdag 8 januari 2010 @ 13:15 | |||||||
Als je bij je hostingboer met dingen als .htaccess files en dergelijke aan de gang kunt kun je gewoon prima een URL als blog.mijnwebsite.nl laten rewriten naar mijnblog.wordpress.com zonder dat de gebruiker dit in zijn adresbalk ziet. | ||||||||
Portugalia | vrijdag 8 januari 2010 @ 14:38 | |||||||
Het abonnement loopt nog twee maanden, ik upgrade het nu en daarna zie ik wel of het me bevalt. Als ik er niet uitkom met de SQL database, meld ik me weer hier! | ||||||||
Chandler | zaterdag 9 januari 2010 @ 23:08 | |||||||
Weet iemand hoe ik de laatste zaterdag van iedere maand kan achterhalen? zonder al te veel scripting te schijven? | ||||||||
Light | zaterdag 9 januari 2010 @ 23:38 | |||||||
quote:Met date('w') kun je achterhalen op welke dag van de week een datum valt. En met mktime() kun je een timestamp maken. Handig om te weten is dat de nulde dag van de maand eigenlijk de laatste dag van de voorgaande maand is. Met een beetje puzzelen zou het dan wel moeten lukken. Veel meer dan 10 regels code hoeft het niet te worden. Ik wil mijn versie wel posten, later Mag je eerst nog even zelf stoeien. | ||||||||
Intrepidity | zaterdag 9 januari 2010 @ 23:50 | |||||||
Dat truucje van de 0e dag kun je inderdaad toepassen, maar met date('n') kun je ook achterhalen hoeveel dagen er in de huidige maand zitten (=laatste dag van de maand) | ||||||||
Tijn | zaterdag 9 januari 2010 @ 23:53 | |||||||
Zoiets?
| ||||||||
Tuvai.net | zaterdag 9 januari 2010 @ 23:54 | |||||||
Wat gebruiken jullie eigenlijk om PDFs on the fly te genereren? Ik gebruik nu al heel lange tijd FPDF ( http://www.fpdf.org ) maar ik ben er elke keer érg lang mee bezig om dynamische documenten te maken, die gedeeltelijk uit variabele content en gedeeltelijk uit vaste content bestaan. Nou is PDF scripts maken sowieso al niet mijn meest favoriete bezigheid, maar in .NET gaat het me een stuk sneller af met de iText / iSharp of dbAutoTrack libraries. Welke raden jullie aan? | ||||||||
Tijn | zaterdag 9 januari 2010 @ 23:55 | |||||||
quote:Ik denk dat je date('t') bedoelt. Dat is inderdaad wel handig en maakt het stukje in mijn code waarin ik dat opzoek overbodig | ||||||||
Intrepidity | zaterdag 9 januari 2010 @ 23:56 | |||||||
Die array met dagen per maand is niet nodig:
Edit: Whoops, t was idd date('t') | ||||||||
GlowMouse | zaterdag 9 januari 2010 @ 23:58 | |||||||
op basis van date('t') en date('w') moet het in veel minder regels kunnen | ||||||||
Tijn | zondag 10 januari 2010 @ 00:01 | |||||||
quote:Hoe zou date('w') het korter maken dan wat hierboven staat? Het zijn trouwens maar 4 effectieve regels, de rest is er om het leesbaarder te maken, maar zou eventueel ook weg kunnen. | ||||||||
Intrepidity | zondag 10 januari 2010 @ 00:02 | |||||||
quote:Omdat je op basis van het dagnummer van de laatste dag in een keer het juiste aantal dagen er vanaf kunt trekken Dan heb je ook geen for-lus meer nodig. | ||||||||
Tijn | zondag 10 januari 2010 @ 00:05 | |||||||
quote:Oh zo. Ja, dan zou je het met een simpel sommetje kunnen oplossen. Slim hoor | ||||||||
GlowMouse | zondag 10 januari 2010 @ 00:07 | |||||||
je krijgt dan zoiets
[ Bericht 4% gewijzigd door GlowMouse op 10-01-2010 00:20:48 ] | ||||||||
Light | zondag 10 januari 2010 @ 00:11 | |||||||
Ik ben nog even verder gaan puzzelen en heb nu een oplossing die Chandler-proof is
Werkt voor alle dagen van de week, gewoon met een parameter. | ||||||||
Tijn | zondag 10 januari 2010 @ 00:14 | |||||||
quote:Hier komt alleen niet het goede antwoord uit | ||||||||
Tuvai.net | zondag 10 januari 2010 @ 00:17 | |||||||
quote:Mooi, en netjes met params. Ik prefereer leesbare, geïndente code over code die zo klein en compact mogelijk moet (tenzij het van belang is voor een merkbare performancewinst natuurlijk) zijn. Dat akelige Perl tijdperk waarin we zo absurd gelimiteerd waren zijn we inmiddels wel voorbij. [ Bericht 5% gewijzigd door Tuvai.net op 10-01-2010 00:22:55 ] | ||||||||
Intrepidity | zondag 10 januari 2010 @ 00:19 | |||||||
Achja, ieder z'n eigen ding he Ik kan er bijvoorbeeld niet tegen om de curly braces naast een klasse/functienaam te zetten Braces staan bij mij altijd op een volgende regel En inderdaad, alles zo compact mogelijk maken heeft nauwelijks zin meer. PHP compileert en optimaliseert zijn code netjes tegenwoordig. | ||||||||
GlowMouse | zondag 10 januari 2010 @ 00:21 | |||||||
quote:nu wel | ||||||||
Intrepidity | zondag 10 januari 2010 @ 00:27 | |||||||
Zo heb ik een keer een leraar voor algoritmiek gehad die in een luie bui het huiswerk zo'n beetje alleen beoordeelde op het aantal coderegels Lang = fout, kort = goed. Heb voor de grap een keer een algoritme ingeleverd met een klein rekenfoutje maar als een hele korte oplossing en hij merkte er niks van Maar tegenwoordig is het: code ruimtelijk opzetten en met veel commentaar, want schermruimte kost toch niks | ||||||||
Light | zondag 10 januari 2010 @ 00:46 | |||||||
quote:Ieder z'n ding idd. Ik vind het zo'n verspilling van ruimte om voor iedere curly brace open weer een nieuwe regel te beginnen. De sluit-brace staat wel op z'n eigen regel (behalve bij een if als er een else volgt). quote:True, leesbaarheid is ook belangrijk. Maar 'k denk niet dat PHP je code zo verandert dat de berekening wordt geoptimaliseerd, dus een efficient algoritme verzinnen moet je wel zelf doen. | ||||||||
Light | zondag 10 januari 2010 @ 00:54 | |||||||
quote:Thanks quote:Eens Hoewel ik wel vaak probeer om code ook compact te houden, maar dat is vooral om dubbele dingen te voorkomen. Op hoe meer plekken je iets moet aanpassen, hoe groter de kans dat je een aanpassing vergeet. | ||||||||
Tuvai.net | zondag 10 januari 2010 @ 01:17 | |||||||
Ik zet curly braces ook meestal op een nieuwe regel, tenzij ik erg veel geneste statements heb waarvan bijvoorbeeld de code in de else blokjes maar één regel per keer is of zo. Het volgende stukje code wordt bijvoorbeeld érg lang als ik alle curly braces op een nieuwe regel zou zetten:
EDIT: En even een schaamteloze repost. quote: | ||||||||
Chandler | zondag 10 januari 2010 @ 08:55 | |||||||
Lol ben ik even wezen slapen en kom terug zie ik een heuse discussie over de laatste zaterdag v/d maand Had zelf ook al een oplossing maar die bestond uit 25 regels waarbij ik alleen de maand/jaar als parameters meegaf. Het moet idd met heel weinig regels code kunnen... eens kijken wat ik met jullie codes kan @Light; jou code is nice en werkt zoals bedoeld! [ Bericht 11% gewijzigd door Chandler op 10-01-2010 09:13:02 ] | ||||||||
wobbel | zondag 10 januari 2010 @ 20:51 | |||||||
quote:Maar stel ik maak een factuur voor de klant aan, voeg ik dan 2 extra regels toe? Veld "Periode" dus 14, 31, 365 Veld "Aantal" -1 is ongelimiteerd doorgaan, of 12 voor 12 maanden (als je voor 31 dagen hebt gekozen) Of periode + aantal opgeven, en dan dmv een cronjob elke dag controleren of er een factuur gegenereerd moet worden. En dan als je maandelijks kiest dat hij het altijd op de 15e doet bijv.? | ||||||||
Tijn | zondag 10 januari 2010 @ 21:03 | |||||||
quote:Ik zou zorgen dat je bij het aanmaken van een factuur de datum kunt opgeven waarop 'ie verzonden moet worden en dat geheel dan kunt opslaan in je database. Vervolgens run je elke dag een cronjob die een script aanroept die kijkt of er facturen zijn die vandaag verzonden moeten worden en zo ja, dan doet 'ie dat. | ||||||||
Tuvai.net | zondag 10 januari 2010 @ 21:59 | |||||||
quote:Tja, dat is natuurlijk een kwestie van je fantasie gebruiken, en volledig afhankelijk van je script en hetgeen je wilt doen. Ik heb een paar weken geleden nog een applicatie gemaakt waarbij op vaste tijdstippen diverse mailtjes naar leden verzonden moesten worden, volledig automatisch. Denk daarbij aan vaste tijdstippen als: - Elke maandag om 11:35 - Elke woensdag om 17:00 - Elke vrijdag om 18:30 En dan nog een stuk of 20 van zulke tijdstippen. Het is allemaal niet zo ingewikkeld. Je maakt gewoon een applicatie die elke x aantal minuten draait. In die applicatie kijk je wat de huidige tijd is (gewoon de tijd van uitvoering dus), en daaraan koppel je eventuele handelingen die op dat tijdstip moeten plaats vinden. Vaak houdt dat dan ook in dat je bij moet houden of iets al gebeurt is. Bijvoorbeeld: Je applicatie draait op maandag 1 januari 17:00 en daardoor wordt een factuur voor januari 2010 naar lid ID #1 verzonden. Dan zul je ergens bij moeten houden dat die factuur voor dat lid reeds verzonden is, zodat je applicatie die factuur niet de volgende keer wéér gaat versturen. Je daadwerkelijke functionele code die je normaliter zou hebben (dus in geval van géén automatisme), blijft in de meeste gevallen ongewijzigd. Denk aan het daadwerkelijk genereren van een factuur PDF`je of DOC`je. Het is alleen de manier van aanroepen die in geval van een dergelijk geautomatiseerde applicatie anders is. | ||||||||
Tuvai.net | zondag 10 januari 2010 @ 22:01 | |||||||
Maare, niemand maakt hier dus dynamische PDFs in PHP? | ||||||||
Intrepidity | zondag 10 januari 2010 @ 22:16 | |||||||
quote:Jewel, met FPDF vanwege gebrek aan beter, dus ik kan je niet verder helpen Je kunt naar de PDF module van PHP zelf kijken (http://php.net/manual/en/book.pdf.php), maar ik zie niet 1,2,3 in hoe dat beter is als FPDF | ||||||||
Tuvai.net | zondag 10 januari 2010 @ 23:03 | |||||||
quote:Ook al FPDF dus. De standaard PDF functies van PHP staan naar mijn ervaring erg vaak uitgeschakeld en die kun je in geval van een third party host ook niet even aanzetten. | ||||||||
Intrepidity | zondag 10 januari 2010 @ 23:25 | |||||||
Je zou eens naar PDML kunnen kijken: http://www.pdml-pdf.net/ Dat is een laag bovenop FPDF met een soort HTML-achtige syntax. Heb het nog niet geprobeerd, maar als het doet wat het belooft maakt dat het opmaken van documenten in ieder geval een stuk makkelijker, hoewel ik me kan voorstellen dat door al die lagen de performance wat tegenvalt.. | ||||||||
Tuvai.net | zondag 10 januari 2010 @ 23:30 | |||||||
Het stikt op Internet van de PDF libraries (voor vrijwel elk populair platform), maar in plaats van die allemaal uit te gaan proberen (waar ik de tijd niet voor heb: P ) was ik gewoon eens nieuwsgierig naar wat mensen hier gebruiken, en wat hun ervaringen zijn. | ||||||||
wonderer | maandag 11 januari 2010 @ 05:29 | |||||||
Ik word hier echt gestoord van... mail() stuurt twee keer dezelfde mail... en ik snap niet waar het aan ligt.
Dus. Dat is de functie. Iemand "bestelt" iets via een formulier ('t is echt meer geautomatiseerde spreadsheet om bij te houden wie hoeveel besteld heeft zodat ik het niet met de hand hoef te doen dan een echt betaalsysteem en alles), krijgt een linkje, klikt daarop om de bestelling te bevestigen (voornamelijk om het e-mailadres te checken en te zorgen dat iemand niet "voor de lol iets bestelt"). Werkt verder prima, maar je krijgt de bevestigingsmail twee keer. Het grappige is, als je nog een keer op de bevestigingslink klikt, krijg je (zoals in de functie te zien is) de mail opnieuw zonder het te bevestigen, maar dan krijg je hem maar een keer... En als ik de database update uitzet en op de link blijf klikken, krijg ik de volgende keren er maar eentje. Ook al wordt hetzelfde script uitgevoerd. Ik snap er geen flikker van. Iemand dit eerder bij de hand gehad? Staat nogal onprofessioneel, die twee mails :') | ||||||||
Intrepidity | maandag 11 januari 2010 @ 07:12 | |||||||
Zo op het eerste gezicht lijkt die functie in orde. Ik vermoed dan ook dat die functie ergens 2 keer aangeroepen wordt.. | ||||||||
Sitethief | maandag 11 januari 2010 @ 11:59 | |||||||
Iemand ervaring met MODx? Ik ben er nu een beetje mee aan het stoeien, maar het ziet er allemaal heel tof uit. | ||||||||
Tijn | maandag 11 januari 2010 @ 12:06 | |||||||
quote:Als je met zoiets aan de slag gaat, kun je je dan niet beter storten op bv Zend Framework? | ||||||||
Sitethief | maandag 11 januari 2010 @ 12:40 | |||||||
quote:Opdracht van de baas . | ||||||||
PiRANiA | maandag 11 januari 2010 @ 13:20 | |||||||
Geeft: quote:Iemand enig iedee hoe dat kan? :) | ||||||||
PiRANiA | maandag 11 januari 2010 @ 13:21 | |||||||
O ik zie het nu. Het is een multidimensionale array | ||||||||
Sitethief | maandag 11 januari 2010 @ 13:55 | |||||||
Wat is er mis met
Dat ziet er wat leesbaarder uit vind ik altijd. [ Bericht 2% gewijzigd door Sitethief op 11-01-2010 14:35:31 (var_dump ipv print_r) ] | ||||||||
PiRANiA | maandag 11 januari 2010 @ 14:05 | |||||||
quote:Kan ook | ||||||||
hamkaastosti | maandag 11 januari 2010 @ 14:20 | |||||||
ik gebruik altijd var_dump want die geeft meer bruikbare informatie | ||||||||
Light | maandag 11 januari 2010 @ 14:26 | |||||||
quote:Helemaal als je ook iets van xdebug geinstalleerd hebt (op de server). | ||||||||
ursel | maandag 11 januari 2010 @ 14:26 | |||||||
quote:Hier ook, verwerkt in een kleine functie dump, zodat ik niet elke keer dat moet tikken.. | ||||||||
Sitethief | maandag 11 januari 2010 @ 14:34 | |||||||
Ik bedoelde natuurlijk <pre>, niet print_r, wat je verder voor function of wat dan ook gebruikt was niet mijn punt . | ||||||||
wonderer | maandag 11 januari 2010 @ 18:42 | |||||||
quote:Nee, want als ik na of voor de mail() functie een echo doe om dat te testen, wordt dat maar een keer afgedrukt. En dan zou het altijd twee mailtjes moeten zijn, niet alleen de eerste keer dat je op de link in het mailtje klikt. | ||||||||
ParvusM | maandag 11 januari 2010 @ 19:28 | |||||||
quote:Uhm, als de Functie 2x word aangeroepen, dan betekent dat niet dat de echo voor of na de functie 2x word aangeroepn, dus dat is geen handige manier om het te testen. Je zou dan de echo IN de functie moeten zetten. | ||||||||
wonderer | maandag 11 januari 2010 @ 20:02 | |||||||
quote:Heb je het nou over de hele functie (confirm_order()), of mail()? Waarom zou mail() binnen de functie in vredesnaam twee keer worden aangeroepen als het er maar een keer staat? | ||||||||
Light | maandag 11 januari 2010 @ 20:48 | |||||||
quote:Met XDebug heb je ook geen <pre> nodig. | ||||||||
Intrepidity | dinsdag 12 januari 2010 @ 22:28 | |||||||
Al de PHP applicaties die we maken binnen het bedrijf waar ik werk draaien op een door mij geschreven MVC-framework, en die apps hebben een aantal configuratiebestanden. Momenteel ben ik aan het kijken waar binnen het framework performancewinst te halen valt, en een van de aandachtspunten zijn de configuratiefiles, die momenteel als XML-data zijn opgeslagen, omdat ik het idee heb dat er snellere situaties denkbaar zijn als het parsen van een XML-bestand. Eerst hadden we een pure PHP-array, maar vanwege het feit dat XML makkelijker vanuit PHP te manipuleren is (op een persistente manier dan) hebben we voor XML gekozen. Hoe doen julie dat eigenlijk met configuratiebestanden. Een array? XML? Database? Flat text wellicht? Wat geeft de beste performance EN de mogelijkheid om er eventueel later iets als een CMS-module omheen te bouwen? Ik zit zelfs nog te denken om de XML-files na iedere mutatie te 'cachen', dus er een PHP-array van te genereren, maar dit voelt een beetje aan als overkill | ||||||||
Chandler | dinsdag 12 januari 2010 @ 22:39 | |||||||
Klein vraagje, ik wil de keys van een array omdraaien, hoe kan ik dit doen? Dus voorbeeld: 0 = a 1 = b 2 = c moet worden 0 = c 1 = b 2 = a kon dit nergens vinden (nou kijk ik ook vaak niet goed maar vond echt nix ) | ||||||||
Intrepidity | dinsdag 12 januari 2010 @ 22:46 | |||||||
Is dat niet exact hetzelfde als de waarden omdraaien zonder behoud van keys? In dat geval kun je dit doen:
Dat bovenstaande werkt overigens niet als de keys niet op volgorde staan of er gaten in de reeks van keys zitten.. Dan zul je een handmatigere aanpak moeten nemen. | ||||||||
hamkaastosti | dinsdag 12 januari 2010 @ 22:46 | |||||||
2 arrays maken met array_keys en array_values. 1 v.d. 2 reversen met array_reverse en vervolgens weer een nieuwe array maken met array_combine? @glowmouse array_flip wisselt alleen de key met de value toch? oeh.. array_reverse werkt wel als ik de manual zo lees | ||||||||
GlowMouse | dinsdag 12 januari 2010 @ 22:46 | |||||||
array_flip oh zonder key preserve; dan array_reverse. | ||||||||
Intrepidity | dinsdag 12 januari 2010 @ 22:49 | |||||||
quote:array_flip doet iets anders. Die zorgt dat keys en waarden omgedraaid worden, dus array(0 => 'a', 1 => 'b') wordt array('a' => 0, 'b' => 1) |