1 2 3 4 | <a class="list" href="/loggedin/torrent.do?info_hash=7af1f52fe37cfce27f64157538a714be24aea012">Season 6 Prequel</a><br> <a class="admin" href="/loggedin/TorrentLoaderServlet?info_hash=7af1f52fe37cfce27f64157538a714be24aea012">download</a></td> ?> |
1 2 3 4 | $html = file_get_contents(LINK ZET IK HIER NIET NEER NATUURLIJK); if(preg_match_all('/loggedin/TorrentLoaderServlet?info_hash=([a-f0-9]{40,})/',$html,$matches)) ?> |
Dank u. Ik moet helaas voorlopig nog met PHP4 werken, maar dat eerste artikel heeft wel het een en ander verduidelijkt.quote:Op vrijdag 5 januari 2007 18:58 schreef beerten het volgende:
http://www.phpfreakz.nl/artikelen.php?aid=99
http://www.phpfreakz.nl/artikelen.php?aid=116
Moet die {40,} geen {40} zijn? Mijn editor vind hem dan lief.quote:Op vrijdag 5 januari 2007 22:09 schreef qu63 het volgende:
stukje code wat op een website staat:
[ code verwijderd ]
mijn regexp om de download-link er uit te vissen:
[ code verwijderd ]
ergens gaat het fout..
mn regexp moet de hash-code van 40 tekens uit de link vissen en deze uitspugen.
iemand tips waar de fout zit/hoe het beter kan?
1 2 3 4 5 6 | count(weblog_posts.subdomein) AS totalPost FROM weblogs LEFT JOIN weblog_posts ON weblog_posts.subdomein = weblogs.subdomein HAVING totalPost > 0 GROUP BY weblogs.subdomein |
1 2 3 4 5 | weblogs.subdomein 2 weblog_posts weblogs.subdomein, weblogs.datumtijd |
"Unknown modifier 'T' " krijg ik dan..quote:Op vrijdag 5 januari 2007 23:06 schreef fokME2 het volgende:
[..]
Moet die {40,} geen {40} zijn? Mijn editor vind hem dan lief.
In posts staat het aantal postings? Waarom ga je dan in vredesnaam group by uitvoeren als je al een tabel met de aantallen hebt?quote:Op zaterdag 6 januari 2007 12:09 schreef Chandler het volgende:
Klein vraagje
[ code verwijderd ]
als ik having er in zet werkt het niet! maar ik wil graag alle resultaten hebben waar de count groter is dan 0 of in een andere query gelijk aan 0
Wat doe ik fout?
uitleg:
ik heb 2 tabellen.
[ code verwijderd ]
in weblogs staan de gebruikers en in posts staan het aantal postings. nu wil ik van iedere weblogger weten hoeveel postings er zijn en op welke datum de laaste is aangemaakt...
/i erachter en /T ipv /T werktquote:Op vrijdag 5 januari 2007 22:09 schreef qu63 het volgende:
stukje code wat op een website staat:
[ code verwijderd ]
mijn regexp om de download-link er uit te vissen:
[ code verwijderd ]
ergens gaat het fout..
mn regexp moet de hash-code van 40 tekens uit de link vissen en deze uitspugen.
iemand tips waar de fout zit/hoe het beter kan?
quote:Ik was aan het zoeken naar informatie over mysql beveiligingen en vond wat ik zoch. Heb er een kleine samenvatting van gemaakt met vooral code voorbeelden (klein beetje uitleg) en wilde het hier even delen. Heb je toevoegingen post het!
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 | /* Dit kleine documentje gaat over het beveiligen van data m.b.t. het hacken van databases! gebruik: $_GET maar $_POST kan ook ;) (of zelfs $_FILES :P) ** validatie checks */ // Nummeriek if (isSet($_GET['voorbeeld']) && is_numeric($_GET['voorbeeld'])) // textueel en cijfers if (!ereg("^[_a-zA-Z0-9]*$", $_POST['voorbeeld']) ) // alleen text if (!ereg("^[_a-zA-z]*$",$_POST['voorbeeld'])) { /* !eregi("[_a-z0-9-]+@[a-z0-9-]+.[a-z0-9-]", $_POST['email']) LET OP; simpele versie, betere varianten op internet te vinden.!) nu het stukje om mysql injection te voorkomen. ** injectie beveiliging */ // verwijderen van foutieve elementen uit variabel, slechts een voorbeeld. $str_replace(array("(", ")", ";", "'", "%27", "="), "", $_GET['voorbeeld']); // omzetten naar= htmlspecialchars($_GET['voorbeeld']); // of verwijderen van slashes (kan bter ;)) stipslashes($_GET['voorbeeld']) /* en zo zijn er nog meerdere, anyone more? */ ?> |
forum:quote:Op zondag 7 januari 2007 00:12 schreef X-fi het volgende:
Weet iemand hoe ik het volgende moet scripten?
Ik heb twee images:
(http://www.worldracing.nl/images/download/wallpapers/pspworldracingwallpaper.jpg (480×272))
(http://www.worldracing.nl/images/download/wallpapers/pspworldracingwallpapersmall.jpg (240×138))
De "pspworldracingwallpapersmall.jpg" is de afbeelding die je te zien krijgt in de download sectie. En als je daarop klikt krijg je de grotere versie van te zien. (dus de "pspworldracingwallpaper.jpg").
Kan iemand mij helpen daarmee aub?
1 |
1 |
Dank je, dit werk!quote:
1 2 3 4 5 6 7 8 | { } else { $id = ID /='". $_GET['id'] ."'; } |
1 |
quote:Op maandag 8 januari 2007 11:55 schreef Darkomen het volgende:
$id = 'ID = '. $_GET['id'];
1 |
1 |
1 2 3 | $string = "dit is een string"; ?> |
1 2 3 4 5 6 | //dit kan niet $string = 'test".$var."string'; //zo werkt ie wel $string = "test".$var."string"; ?> |
1 2 3 4 5 | $string1 = "dit is string1"; $string2 = " en dit is string2"; $string = $string1.$string2; ?> |
1 2 3 | $sql = "SELECT * FROM problementabel WHERE id = ".$id." AND Korte_Omschrijving LIKE "1""; ?> |
of als iemand voor mij de tabel er wil uitvissen is dat natuurlijk ook mooi, meer is het namelijk niet! sql is gezipt maar 11 mb groot, kan deze op mijn server plaatsen voor degene die mijn redder wil zijn!quote:Op maandag 8 januari 2007 13:38 schreef Spockjuh_ het volgende:
zit met een probleem. heb een sql backup gemaakt die ik lokaal moet aanpassen. reden hiervoor is dat uiploaden niet mogelijk is omdat ik de max overstijg van 51.600. nu ga ik er vanuit dat ik mysql en apache server lokaal heb moeten draaien om een aanpassing te maken in de sql database, maar beide softwarepakketten heb ik niet. iemand die mij hiermee kan helpen? d sql is 360 mb groot, gezipt maar 11mb. er moet 1 tabel worden uitgehaald.
http://www.apachefriends.org/en/xampp.html doet het altijd prima bij mij,quote:Op maandag 8 januari 2007 16:09 schreef Spockjuh_ het volgende:
[..]
of als iemand voor mij de tabel er wil uitvissen is dat natuurlijk ook mooi, meer is het namelijk niet! sql is gezipt maar 11 mb groot, kan deze op mijn server plaatsen voor degene die mijn redder wil zijn!
Je kunt de SQL backup dan gewoon importeren in je MySQL database via bijvoorbeeld PHPMyAdmin of MySAL Administrator (van mysql.org) en dan de juiste tabel eruit vissen.quote:Op maandag 8 januari 2007 16:50 schreef Spockjuh_ het volgende:
ok, geinstalleerd en het draait. alleen het stapje van mijn sql openen en aanpassen kan ik nog even niet vinden, ook niet na het doorlezen van de help
Daar werk ik niet meequote:Op dinsdag 9 januari 2007 10:25 schreef super-muffin het volgende:
Ja die query is goed.
(je kunt trouwens ook die query in PHPmyAdmin invoeren en kijken wat dat terug geeft.)
Het is niet verstandig om de variabele $id zo in een SQL query te zetten. Beter is het om de GET variabele id te valideren om SQL injectie te voorkomen. Je wilt er zeker van zijn dat de opgegeven id-waarde numeriek is en dus zou je op de volgende manier de waarde kunnen valideren:quote:Op maandag 8 januari 2007 11:55 schreef Darkomen het volgende:
$id = 'ID = '. $_GET['id'];
1 2 3 4 5 | { $id = 'ID = ' . $_GET['id']; // Verdere code waaronder uitvoeren van de SQL query. } |
klopt maar aangezien beide pc's op het zelfde netwerk staan kan ik met een unc pad in php ook andere pc's in het netwerk benaderen..quote:Op donderdag 11 januari 2007 00:05 schreef hornage het volgende:
php is serverside dus daarmee kan je op de server waarop hij draait files browsen.
javascript is clientside, als je dus op de client naar files wilt zoeken oid moet dat met javascript. De gevonden info kan daarna altijd met een form doorgestuurd worden naar php
ik had inmiddels zelf ook wel iets in gedachte waarmee ik het in php kon doen (ik heb immers al een functie die directory's langs gaat voor bestanden) die kan ik aanpassen voor alleen directory'squote:Op donderdag 11 januari 2007 10:07 schreef ralfie het volgende:
Je kunt vast wel iets verzinnen met php en javascript? Is nog niet eens zoveel werk om van een aantal directories zoiets te maken
[afbeelding]
Je moet alleen goed met css en javascript alles uitlijnen en klikbaar maken.
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 | function getdir($path) { $dirStack = array($path); $dirs = array(); while (null !== ($dir = array_pop($dirStack))) { $dh = opendir($dir) or die('Error: Could not open directory: '.$dir); while (false !== ($file = readdir($dh))) { $skipDirs = array('.', '..', 'System Volume Information', 'Temporary Internet Files', 'Temp', 'WINDOWS','$RECYCLE.BIN','RECYCLER'); if (!in_array($file,$skipDirs)) { $fullFile = $dir . $file; if (is_dir($fullFile)) { $dirs[] = $fullFile. '\'; $dirStack[] = $fullFile . ''; } } } closedir($dh); } return $dirs; } ?> |
.quote:Op donderdag 11 januari 2007 19:04 schreef mschol het volgende:
ahh thnx voor de voorbeelden, inmiddels ook me php functie verbouwd zodat ik alleen directory's terug krijg
nu beide zien te combineren...
mijn php functie ziet er zo uit:
[ code verwijderd ]
ik krijg dus nu een array met alle sub directory's behalve de mappen die in $skipdirs voor komen
hmmm ik krijg het niet voor elkaar om een level te generenen (wat mij sneller lijkt dan met regex'en te checken hoeveel \ erin de directory staan (en ik dus kan bepalen waar de directory zich bevind, de root, 1 map diep of 2 of 3 mappen diep.)
1 2 3 | $dirs[] = $fullFile. '\'; ?> |
Jij doet het ook niet.quote:Op vrijdag 12 januari 2007 17:31 schreef fate het volgende:
[..]
.
In je code zit in elk geval een fout zoals je kan zien aan de highlighting.
[ code verwijderd ]
Je moet de \ escapen.
aha, in me source stond hij wel goedquote:Op vrijdag 12 januari 2007 17:31 schreef fate het volgende:
[..]
.
In je code zit in elk geval een fout zoals je kan zien aan de highlighting.
[ code verwijderd ]
Je moet de \ escapen.
Ja, dat wel...quote:Op vrijdag 12 januari 2007 21:21 schreef JeRa het volgende:
Staat die regel 585 toevallig in een for(each)- of while-loop?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 | if(is_dir("$path/$file")) { // Its a directory, so we need to keep reading down... $dirs[] .= "$level|$Parentnode|$path$file"; $Parentnode = array_search(array_search($level."|".$Parentnode."|".$path.$file, $dirs), array_keys($dirs)); $temp_dir = getDirectory("$path$file/", ($level+1),$Parentnode); if(is_array($temp_dir)) { foreach($temp_dir as $key => $data) { $dirs[] .= $data; } } // Re-call this same function but on a new directory. // this is what makes function recursive. } ?> |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 | [1] => 2|0|d:/Apache/bin [2] => 2|0|d:/Apache/cgi-bin [3] => 2|1|d:/Apache/conf [4] => 3|2|d:/Apache/conf/ssl [5] => 2|2|d:/Apache/htdocs [6] => 3|4|d:/Apache/htdocs/manual [7] => 4|0|d:/Apache/htdocs/manual/howto [8] => 4|0|d:/Apache/htdocs/manual/images [9] => 4|1|d:/Apache/htdocs/manual/misc [10] => 4|2|d:/Apache/htdocs/manual/mod [11] => 4|3|d:/Apache/htdocs/manual/programs [12] => 4|4|d:/Apache/htdocs/manual/vhosts [13] => 2|4|d:/Apache/icons [14] => 3|12|d:/Apache/icons/small [15] => 2|12|d:/Apache/include |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 | [1] => 2|0|d:/Apache/bin [2] => 2|0|d:/Apache/cgi-bin [3] => 2|0|d:/Apache/conf [4] => 3|3|d:/Apache/conf/ssl [5] => 2|0|d:/Apache/htdocs [6] => 3|5|d:/Apache/htdocs/manual [7] => 4|6|d:/Apache/htdocs/manual/howto [8] => 4|6|d:/Apache/htdocs/manual/images [9] => 4|6|d:/Apache/htdocs/manual/misc [10] => 4|6|d:/Apache/htdocs/manual/mod [11] => 4|6|d:/Apache/htdocs/manual/programs [12] => 4|6|d:/Apache/htdocs/manual/vhosts [13] => 2|0|d:/Apache/icons [14] => 3|13|d:/Apache/icons/small [15] => 2|0|d:/Apache/include |
Waarschijnlijk krijg je onder bepaalde voorwaarden een oneindige loop.quote:Op vrijdag 12 januari 2007 21:27 schreef wonderer het volgende:
[..]
Ja, dat wel...
Maar dan snap ik nog niet waarom hij dan soms loopt te mieren en meestal niet. Hij wordt wel vaak aangeroepen, kan het daaraan liggen?
En proberen te ontdekken welke voorwaarden is zeker onbegonnen werk?quote:Op vrijdag 12 januari 2007 21:42 schreef Light het volgende:
[..]
Waarschijnlijk krijg je onder bepaalde voorwaarden een oneindige loop.
Ik blijf bij een oneindige loop. Het aantal keren dat je die regel aanroept is niet zozeer het probleem, een loop die 1 keer oneindig wordt (while(true)) wel.quote:Op vrijdag 12 januari 2007 21:27 schreef wonderer het volgende:
[..]
Ja, dat wel...
Maar dan snap ik nog niet waarom hij dan soms loopt te mieren en meestal niet. Hij wordt wel vaak aangeroepen, kan het daaraan liggen?
Wat voor problemen? En wat is de query? En wat doe je met $result?quote:Heb ook problemen met $result=mysql_db_query($myDB,$query,$dblink); en een aantal dingen die daaruit voortvloeien... waar kan dat op duiden?
Neuh. Hoe is die loop? Dus wat is de for(each) of while regel van die loop waarin regel 585 zit?quote:Op vrijdag 12 januari 2007 21:44 schreef wonderer het volgende:
[..]
En proberen te ontdekken welke voorwaarden is zeker onbegonnen werk?
quote:Op vrijdag 12 januari 2007 21:45 schreef Light het volgende:
[..]
Ik blijf bij een oneindige loop. Het aantal keren dat je die regel aanroept is niet zozeer het probleem, een loop die 1 keer oneindig wordt (while(true)) wel.
[..]
Wat voor problemen? En wat is de query? En wat doe je met $result?
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 | $d=connectDB(); $qroom=quote_smart($kamer,$d); $qroom=make_room($qroom); $success=settype($ID,"int"); $res=runquery("SELECT * FROM chat_kamer_".$qroom." WHERE ID > '".$ID."'",$d); if(mysql_num_rows($res)!=0){ while($row=mysql_fetch_array($res)){ $id=$row["ID"]; $username=$row["username"]; $chatname=parse_chatname($row["chatname"], $username); $kleur=$row["kleur"]; $sentence=parse_sentence($row["sentence"],$row["systemmess"]); $line=lineformat($id, $chatname, $kleur, $sentence, $row["adminmess"], $username, $row["systemmess"]); $lines.=$line.'<%split%>'; $lid=$row["ID"]; } $lines=substr($lines,0,-9); $callback=$lid.'<%split%>'.$lines; return $callback; } else{ return ''; } ?> |
Hmm... ik heb hier eens naar gekeken, maar ik kan niet vinden hoe die loop oneindig kan worden.quote:Op vrijdag 12 januari 2007 22:01 schreef wonderer het volgende:
[..]
[ code verwijderd ]
$ID wordt meegegeven in de functie. Functie wordt gebruikt om te zien of er nieuwe dingen gezegd zijn en zo ja, laat ze dan zien. Wordt elke twee seconden aangeroepen via een javascript.
$result is dezelfde als $d. 't Is mijn databaseverbindingsfunctie, die dus eerst aangeroepen wordt en gebruikt voor de query en de magic quotes gedoe.
Correct. En er zijn een paar mogelijke redenen waarom 30 seconden niet genoeg is. Zo kun je gewoon zoveel code hebben gemaakt dat het niet meer binnen 30 seconden uit te voeren is door de pc. Maar da's niet waarschijnlijk.quote:Op zaterdag 13 januari 2007 00:10 schreef hornage het volgende:
jongens,
Fatal error: Maximum execution time of 30 seconds exceeded in /var/www/path/to/chatscript.php
betekent simpelweg dat alles bewerkingen die gedaan worden om de pagina te laden meer dan 30 seconden in beslag nemen. Vanaf het moment dat de pagina aangevraagd wordt totdat ie klaar met laden is mag niet meer dan 30 seconden in een standaardinstelling.
1 2 3 4 5 6 7 | $i=0; while (true) { $i++; } echo $i; ?> |
Queries controleren is idd ook een goed plan.quote:Als dit alle code is waarin hij blijft hangen kan je even de query testen in bijvoorbeeld phpmyadmin. Als je daarin wel gewoon snel output krijgt ligt het aan je script.
Kijk wat er allemaal geladen en geiclude wordt. Dan moet je vast en zeker wel wat vinden.
Hmm.. goed puntquote:Op vrijdag 12 januari 2007 23:34 schreef wonderer het volgende:
Zijn er andere manieren om een database verbinding aan te maken?
En wat zou er bijvoorbeeld gebeuren als ID 0 was? De huidige meest recente IDs liggen rond de 500.000 (niet dat er zoveel records in zitten, maar ik laat hem doortellen).
1 2 3 4 5 6 7 8 | ( [0] => 054 [1] => 121 [2] => 232 [3] => 45822 [4] => 12 } |
quote:Op zaterdag 13 januari 2007 11:11 schreef SuperRembo het volgende:
Zoeken in een array, gokje: array_search()
Dan moet het hele OO concept beter verwerkt worden in PHP.quote:Op zaterdag 13 januari 2007 12:25 schreef JeRa het volgende:
Arrays zijn nou typisch van die dingen in PHP waarvan ik zou willen dat ze net zoals in Java als extendable class werden geïntroduceerd. Dan had je niet overal meer die losse functies als sort() en count() liggen en was bovenstaand probleem gereduceerd tot Array.indexOf() of desnoods gewoon Array.findKey().
Ik vind dat ze al een redelijke basis hebben voor OOP in PHPquote:Op zaterdag 13 januari 2007 17:19 schreef Light het volgende:
[..]
Dan moet het hele OO concept beter verwerkt worden in PHP.
Ze maken wel een nieuwe verbinding aan (zelfde weer, $d=connectDB();) in de functies... hoeft dat niet? Kan dat anders? Misschien kan ik in de functie runquery inbouwen dat ie alleen verbinding moet maken als er geen verbinding is, maar dan weet ik niet hoe ik die magic_quotes_gpc moet doen...quote:Op zaterdag 13 januari 2007 10:55 schreef JeRa het volgende:
Met die loop lijkt me zo niets mis. Doen parse_chatname() en parse_sentence() nog iets vreemds, zoals verbindingen maken met de DB en trage queries executen ofzo?
Een goede start is het doorgeven van de $db uit het hoofdscript. Die verbinding heb je namelijk al gemaakt dus dan hoeven die functies dat niet telkens opnieuw te doen. Ik heb sterk het vermoeden dat die twee functies zo slecht in elkaar zitten dat zij de oorzaak zijn van die 30+ seconden runtimequote:Op zaterdag 13 januari 2007 18:34 schreef wonderer het volgende:
[..]
Ze maken wel een nieuwe verbinding aan (zelfde weer, $d=connectDB();) in de functies... hoeft dat niet? Kan dat anders? Misschien kan ik in de functie runquery inbouwen dat ie alleen verbinding moet maken als er geen verbinding is, maar dan weet ik niet hoe ik die magic_quotes_gpc moet doen...
Heb je een linkje naar een tut waar goed wordt uitgelegd hoe je functies (en database dingen) opbouwt? Er moet best wel een hoop gedaan worden voor de zin er mooi leesbaar uit komt rollen...quote:Op zaterdag 13 januari 2007 18:49 schreef JeRa het volgende:
[..]
Een goede start is het doorgeven van de $db uit het hoofdscript. Die verbinding heb je namelijk al gemaakt dus dan hoeven die functies dat niet telkens opnieuw te doen. Ik heb sterk het vermoeden dat die twee functies zo slecht in elkaar zitten dat zij de oorzaak zijn van die 30+ seconden runtime
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 | if($_POST['submit']="submit") { $id = $_POST['ID']; $datum = $_POST['datum']; $offertenummer = $_POST['offertenummer']; $ordernummer = $_POST['ordernummer']; $order = $_POST['order']; $bedrag = $_POST['bedrag']; if (is_array($id) && (count($id))) { $query = 'UPDATE (ID,datum,offertenummer,ordernummer,offerte,bedrag) VALUES (' . $id[0] . ', ' . $datum[0] . ', ' . $offertenummer[0] . ', ' . $ordertenummer[0] . ', ' . $order[0] . ', ' . $bedrag[0] . ')'; $num = count($id); for ($i = 0; $i < $num; $i++) { $query .= ',(' . $id[$i] . ', ' . $datum[$i] . ', ' . $offertenummer[$i] . ', ' . $ordernummer[$i] . ', ' . $order[$i] . ', ' . $bedrag[$i] . ')'; } mysql_query($query); } } ?> |
Waarom niet gewoon een loop schrijven die per array-regel een volledige query uitvoert? En waarom gebruik je daarvoor de update query en niet de insert query?quote:Op zondag 14 januari 2007 10:39 schreef qu63 het volgende:
[ code verwijderd ]
hoe kan ik deze query nou goed laten gaan?
$id t/m $bedrag moeten meerdere waarden krijgen (een array dus) en die moeten allemaal de database in. Er komen geen nieuwe rijen bij, het wordt dus alleen maar geupdate.
ik keek al bij Multiple Queries op dev.mysql.com maar ik weet niet of dat allemaal goed werkt enzo..
iemand tips?
mij leek een enkele query makkelijker om uit te voeren, maar dat was idd mijn optie als dit niet werktequote:Op zondag 14 januari 2007 10:43 schreef zwambtenaar het volgende:
[..]
Waarom niet gewoon een loop schrijven die per array-regel een volledige query uitvoert?
ik haal de waarden uit mn database, daar bouw ik een mooi update-formulier omheen. Dit formulier kan dus ge-submit worden en de nieuwe waarden moeten weer de database inquote:Op zondag 14 januari 2007 10:43 schreef zwambtenaar het volgende:
[..]
Waarom niet gewoon een loop schrijven die per array-regel een volledige query uitvoert? En waarom gebruik je daarvoor de update query en niet de insert query?
Ik begrijp het inderdaad. Als een soort tabel-/spreadsheetoverview waarmee je in één keer vele records kunt editten.quote:Op zondag 14 januari 2007 10:49 schreef qu63 het volgende:
[..]
ik haal de waarden uit mn database, daar bouw ik een mooi update-formulier omheen. Dit formulier kan dus ge-submit worden en de nieuwe waarden moeten weer de database in
juistemquote:Op zondag 14 januari 2007 10:50 schreef zwambtenaar het volgende:
[..]
Ik begrijp het inderdaad. Als een soort tabel-/spreadsheetoverview waarmee je in één keer vele records kunt editten.
Volgens mij doe je de eerste regel (met index 0) nu dubbel.quote:Op zondag 14 januari 2007 10:39 schreef qu63 het volgende:
[ code verwijderd ]
hoe kan ik deze query nou goed laten gaan?
[...]
iemand tips?
ohja 8)7quote:Op zondag 14 januari 2007 12:27 schreef SuperRembo het volgende:
[..]
Volgens mij doe je de eerste regel (met index 0) nu dubbel.
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 | <table width="50%" border="0" cellspacing="0" cellpadding="0"> <tr> <td>Datum</td> <td>Naam</td> <td>Offertenummer</td> <td>Ordernummer</td> <td>Order</td> <td>Bedrag</td> </tr> <tr><input type="hidden" name="id" value="1"> <td>vandaag</td> <td>Ik</td> <td><input name="offertenummer" value="" size="10"></td> <td><input name="ordernummer" value="" size="10"></td> <td><input name="order" value="ja" size="10">ja/nee</td> <td>¤<input name="bedrag" value="352,79" size="10"></td> </tr> <tr><input type="hidden" name="id" value="2"> <td>5</td> <td>5</td> <td><input name="offertenummer" value="" size="10"></td> <td><input name="ordernummer" value="5" size="10"></td> <td><input name="order" value="5" size="10">ja/nee</td> <td>¤<input name="bedrag" value="5" size="10"></td> </tr> </table> <input type="submit" name="submit" value="submit"> </form> |
1 2 3 | <input type="text" name="offertenummer[]" value="" size="10"> <input type="text" name="offertenummer[]" value="" size="10"> |
1 2 3 4 5 6 7 | $offertenummer = $_POST["offertenummer"]; echo $offertenummer[0]; echo $offertenummer[1]; echo $offertenummer[2]; ?> |
dat komt omdat ik er al een id uit heb geknikkerdquote:Op zondag 14 januari 2007 12:44 schreef HuHu het volgende:
Dan moet je van die input names een array maken.
[ code verwijderd ]
[ code verwijderd ]
Let op dat een array bij 0 begint met tellen en jij je ID's bij 1 laat beginnen.
Aha...quote:Op zondag 14 januari 2007 12:45 schreef qu63 het volgende:
[..]
dat komt omdat ik er al een id uit heb geknikkerd
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 | //dit poept dus alle waarden in een tabelletje.. while ($row = mysql_fetch_assoc($result)) { echo "<tr>n<td>".$row['tijd']."</td>n"; echo "<td>".$row['km']."</td>n"; echo "<td>n<input type="text" name="prijs[".$row['tijd']."][".$row['km']."]" value="".$row['prijs']."">n"; echo "<input type="hidden" name=oud[".$row['tijd'].']['.$row['km']."] value="".$row['prijs']."">n</td>n</tr>n"; } //en dit is de update functie. de rest vavn het script heb ik achterwege gelaten omdat dat alleen maar checks zijn of er iets anders gedaan moet worden.. function update() { //nieuwe waarden? $km = $_POST['km_nieuw']; $prijs = $_POST['prijs_nieuw']; $tijd = $_POST['tijd_nieuw']; if (is_array($km) && is_array($prijs) && is_array($tijd) && (count($km) == count($prijs)) && (count($km) == count($tijd))) { $query = 'INSERT INTO qu63 (tijd, km, prijs) VALUES (' . $tijd[0] . ', ' . $km[0] . ', ' . $prijs[0] . ')'; $num = count($km); for ($i = 0; $i < $num; $i++) { $query .= ',(' . $tijd[$i] . ', ' . $km[$i] . ', ' . $prijs[$i] . ')'; } mysql_query($query); } //if(($_POST['km_nieuw'] > 0) && ($_POST['tijd_nieuw'] > 0) && ($_POST['prijs_nieuw'] > 0)) { //mysql_query('INSERT INTO qu63 (prijs, tijd, km) VALUES ('.$_POST['prijs_nieuw'].','.$_POST['tijd_nieuw'].','.$_POST['km_nieuw'].'),('.$_POST['prijs_nieuw'].','.$_POST['tijd_nieuw'].','.$_POST['km_nieuw'].'),('.$_POST['prijs_nieuw'].','.$_POST['tijd_nieuw'].','.$_POST['km_nieuw'].'),('.$_POST['prijs_nieuw'].','.$_POST['tijd_nieuw'].','.$_POST['km_nieuw'].'),('.$_POST['prijs_nieuw'].','.$_POST['tijd_nieuw'].','.$_POST['km_nieuw'].')'); //mysql_query('INSERT INTO qu63 (prijs, tijd, km) VALUES ('.intval($_POST['prijs'][$tijd][$km]).','.$tijd.','.$km.')'); //$aangepast++; //} //Bij het begin beginnen :) reset($_POST['oud']); //De array bevat tijd, afstand en prijs. //Dat is niet in 1 lus uit te lezen, dus doen we het met twee. while (list($tijd, $tmp) = each($_POST['oud'])) { while (list($km, $prijs) = each($tmp)) { //Als er een andere prijs staat dan zetten we die in de database if($_POST['prijs'][$tijd][$km] != $prijs) { mysql_query('UPDATE qu63 SET prijs = '.intval($_POST['prijs'][$tijd][$km]).' WHERE tijd = '.$tijd.' AND km = '.$km); $aangepast++; } } } } ?> |
dat werkt iig ja..quote:Op zondag 14 januari 2007 12:44 schreef HuHu het volgende:
Dan moet je van die input names een array maken.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 | mysql_connect(DB_HOST, DB_USER, DB_PASS); mysql_select_db(DB_DATABASE); $id = $_POST['ID']; $datum = $_POST['datum']; $naam = $_POST['naam']; $offertenummer = $_POST['offertenummer']; $ordernummer = $_POST['ordernummer']; $order = $_POST['order']; $bedrag = $_POST['bedrag']; $nieuw = array($id,$datum,$naam,$offertenummer,$ordernummer,$order,$bedrag); //print_r($nieuw); //echo $nieuw[3][1]; if (is_array($nieuw) && (count($nieuw))) { $num = count($nieuw); for ($i = 0; $i < $num; $i++) { // foreach($id as $k => $w) { mysql_query("REPLACE 'order' ('ID', 'datum', 'naam', 'offertenummer', 'ordernummer', 'order', 'bedrag') VALUES('" . $nieuw[0][$i] . "', '" . $nieuw[1][$i] . "', '" . $nieuw[2][$i] . "', '" . $nieuw[3][$i] . "', '" . $nieuw[4][$i] . "', '" . $nieuw[5][$i] . "', '" . $nieuw[6][$i] . "')"); } } ?> |
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 | ( [0] => Array ( [1] => 1 [2] => 2 [3] => 3 ) [1] => Array ( [vandaag] => vandaag [5] => 5 [123] => 123 ) [2] => Array ( [1] => Ik [2] => 5 [3] => 123 ) [3] => Array ( [1] => [2] => [3] => 12 ) [4] => Array ( [1] => [2] => 5 [3] => 789 ) [5] => Array ( [1] => ja [2] => 5 [3] => 55 ) [6] => Array ( [1] => 352,79 [2] => 5 [3] => 333 ) ) |
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 | <table width="50%" border="0" cellspacing="0" cellpadding="0"> <tr> <td>Datum</td> <td>Naam</td> <td>Offertenummer</td> <td>Ordernummer</td> <td>Order</td> <td>Bedrag</td> </tr> <tr><input type="hidden" name="ID[1]" value="1"> <td><input type="hidden" name="datum[vandaag]" value="vandaag">vandaag</td> <td><input type="hidden" name="naam[1]" value="Ik">Ik</td> <td><input name="offertenummer[1]" value="" size="10"></td> <td><input name="ordernummer[1]" value="" size="10"></td> <td><input name="order[1]" value="ja" size="10">ja/nee</td> <td>€<input name="bedrag[1]" value="352,79" size="10"></td> </tr> <tr><input type="hidden" name="ID[2]" value="2"> <td><input type="hidden" name="datum[5]" value="5">5</td> <td><input type="hidden" name="naam[2]" value="5">5</td> <td><input name="offertenummer[2]" value="" size="10"></td> <td><input name="ordernummer[2]" value="5" size="10"></td> <td><input name="order[2]" value="5" size="10">ja/nee</td> <td>€<input name="bedrag[2]" value="5" size="10"></td> </tr> <tr><input type="hidden" name="ID[3]" value="3"> <td><input type="hidden" name="datum[123]" value="123">123</td> <td><input type="hidden" name="naam[3]" value="123">123</td> <td><input name="offertenummer[3]" value="12" size="10"></td> <td><input name="ordernummer[3]" value="789" size="10"></td> <td><input name="order[3]" value="55" size="10">ja/nee</td> <td>€<input name="bedrag[3]" value="333" size="10"></td> </tr> </table> <input type="submit" name="submit" value="submit"> </form> |
Ja natuurlijk is dit mogelijkquote:Op zondag 14 januari 2007 21:14 schreef broodmonkeh het volgende:
Ik heb een datum opgeslagen in de database , nu wil ik zeg maar een overzicht maken van alle gegevens met die datum ouder als een jaar
Dus ik sla het zo op: 2007-01-14 en ik wil zeg maar alle data na 2008-01-14 in een overzicht hebben.
Is dit mogelijk?
met NOW() komt er ook 2007-01-14 uit , dus maakt opzich niet zoveel uit toch? Dat INTERVAL-statement ga ik nu even uitzoeken.quote:Op zondag 14 januari 2007 21:24 schreef fate het volgende:
[..]
Ja natuurlijk is dit mogelijk.
Heb je je data als now() opgeslaan? Dan is het heel wat handiger dan als je het er letterlijk 2007-01-14 inzet...
Je moet maar eens zoeken mbv het INTERVAL-statement in MySQL hoe je data er zo het best gaat uithalen. (Ik geef niet de code omdat je er anders niets van leert)
Jawel, want op DATE en DATETIME velden kan je sql datum en tijd functies gebruiken. op een varchar veld niet.quote:Op zondag 14 januari 2007 22:47 schreef broodmonkeh het volgende:
[..]
met NOW() komt er ook 2007-01-14 uit , dus maakt opzich niet zoveel uit toch?
ik had hem al als DATE veld , gebruikte alleen geen NOW() maar ik had de datum al bepaald met date() en dat in de database gezet.quote:Op zondag 14 januari 2007 22:48 schreef Swetsenegger het volgende:
[..]
Jawel, want op DATE en DATETIME velden kan je sql datum en tijd functies gebruiken. op een varchar veld niet.
Als het maar een DATE veld is. Dan lijkt je methode me nog steeds nodeloos ingewikkeld, mits je een andere datum dan *nu* in de database wil hebben.quote:Op zondag 14 januari 2007 22:55 schreef broodmonkeh het volgende:
[..]
ik had hem al als DATE veld , gebruikte alleen geen NOW() maar ik had de datum al bepaald met date() en dat in de database gezet.
jep dat is ook het gevalquote:Op zondag 14 januari 2007 22:59 schreef Swetsenegger het volgende:
[..]
Als het maar een DATE veld is. Dan lijkt je methode me nog steeds nodeloos ingewikkeld, mits je een andere datum dan *nu* in de database wil hebben.
1 2 3 4 5 6 7 8 | function delete_cookie ( cookienaam ) { var cookie_date = new Date ( ); // current date & time cookie_date.setTime ( cookie_date.getTime() - 1 ); document.cookie = cookienaam += "=; expires=" + cookie_date.toGMTString(); } </script> |
http://www.sitemasters.be/?pagina=tutorials/tutorials&cat=4&id=160quote:Op zondag 14 januari 2007 23:38 schreef profielnaam het volgende:
Ik probeerde in eerste instantie mbv javascript een cookie te verwijderen, maar dit werkt niet zo te zien. de situatie is als volgt:
ik heb een domein waarop de meeste mensen binnenkomen via de index.html op deze pagina wordt een cookie gezet. als de user verder browsed naar een van de andere sites bijv. subdomein.hoofdomein.com dan moet de cookie die eerder op de mainpage gezet is verwijderd worden,
ik probeer dit nu wel met javascript te doen, omdat ik geen PHP ondersteuning heb ik op deze server, misschien dat ik dit er nog bij ga nemen..
ik kwam uit op deze javascript code, welke de cookie expiration time in het verleden zou moeten zetten en daardoor automatisch verwijdert.
De cookie blijft wel staan dus ik doe iets fout..
hopen maar dat iemand me anders wel kan helpen met PHP code hiervoor.
dit is de javascript code iedergeval
[ code verwijderd ]
oké ik heb dit op een andere server gezet als waar de site op draait..quote:Op zondag 14 januari 2007 23:42 schreef Tiemie het volgende:
[..]
http://www.sitemasters.be/?pagina=tutorials/tutorials&cat=4&id=160
Probeer dit eens:quote:Op maandag 15 januari 2007 00:03 schreef profielnaam het volgende:
[..]
oké ik heb dit op een andere server gezet als waar de site op draait..
<?php
// was er in de eerste plaats een cookie geset?
if(isset($_COOKIE['cookienaam'])) {
// verwijder het cookie
setcookie("cookienaam", "description", time()-3600);
}
?>
de cookie >> cookienaam, wordt niet uit de cookies folder verwijderd, wat dus de bedoeling is.
1 2 3 4 5 6 7 | // was er in de eerste plaats een cookie geset? if(isset($_COOKIE['cookienaam'])) { // verwijder het cookie setcookie ("cookienaam", "", time() - 3600); } ?> |
Forum Opties | |
---|---|
Forumhop: | |
Hop naar: |